跟阿斌一块儿学鸿蒙(4). 分布式Hello Harmony的N种写法

目录

假如,鸿蒙能让你用电饭煲来遥控电视...
跟阿斌一块儿学鸿蒙(1). Hello Harmony
跟阿斌一块儿学鸿蒙(2). Ability vs App?
跟阿斌一块儿学鸿蒙(3). 远程虚拟设备的限制和使用方法前端

鸿蒙OS是一个分布式操做系统,而Ability做为它调度的基本单元,那么,一个分布式Hello Harmony能够有几种写法呢?后端

分布式Hello Harmony用例

1. 根据Ability类型

1). FA <-> FA

FA = Feature Ability,用于显示的前台能力。网络

能够理解为两个前端应用在协做。架构

FA/FA模式的Hello Harmony,就是我说Hello, 你说Harmony。框架

在鸿蒙OS中,FA与FA的协做,有三种方式:前后端分离

  • 启动,即一个FA启动另外一个FA
    这严格来讲并不算是一个协做,只是与别的操做系统相似,鸿蒙OS也提供了不一样应用或者进程相互启动的能力。分布式

  • 迁移(转移,流转,接力),即一个界面从一台设备,转移到另外一台设备上。
    例如,导航,查询的时候在手机上,开车的时候在汽车车机上,走路的时候在手表上,甚至耳机上。ide

    例如,视频播放,从手机转移到电视。
  • 协同,多台设备在各自的界面上一块儿完成同一个工做。
    例如,多人一块儿修改一个文档。post

    例如,多人一块儿联机玩游戏。
    
      须要注意的是,在鸿蒙OS的设计中,FA之间的协同,若是不依靠PA的帮助,是很难直接进行的。这就好像是MVC架构中,为了解耦合,不一样的View之间一般并不直接进行交互。
    
      咱们固然能够利用一些非鸿蒙OS独有的特性,例如网络,在不一样FA之间搭建起沟通的桥梁,不过,这就很是不鸿蒙了。

2). FA <-> PA

PA = Particle Ability,不带显示的后台服务能力。ui

前台界面与后台服务进行协做。

FA/PA的Hello Harmony,就是你大声说Hello, 我小声说Harmony。

这种交互,即便是在如今的APP开发中,也是一种常见的先后端分离的架构设计。

利用鸿蒙OS的多设备链接能力,能够方便实现,在最适合显示(交互)的设备上运行FA,而在算力更强更富余的设备上运行PA。

例如,用手机与电视进行游戏,手机充当游戏主机(和手柄),而电视充当显示。

3). PA <-> PA

不一样后台服务进行协做。

PA/PA的Hello Harmony,就是你小声对我说Hello,我也小声回复Harmony。

这样,不一样的PA能够专一负责本身的业务,而后经过组合,完成更复杂的任务。

其实,Data Ability 能够认为就是专门处理数据存储的任务的一个PA,而普通Service Ability则是负责处理具体的任务,利用DA,能够轻松为一个任务增长存储功能。

2. 根据应用

  • 1). 同应用
  • 2). 不一样应用

其实,应用的概念在鸿蒙OS中已经被边缘化了,而Ability才是如今的C位。

因此,并不存在应用A说Hello,应用B说Harmony这种场景,只有Ability A说Hello,Ability B说Harmony的场景。

基于这个设定,其实,咱们不该关心Ability属于哪一个应用,由于每一个Ability都是独立的。

若是你仍是绕不过来,你能够暂时直接认为一个Ability就是一个应用。可是,要注意,在鸿蒙OS中,一个Ability极可能无法像传统的App那样,独立完成一个任务。

而在代码的组织和编写时,对于共同完成一个任务的不一样Ability,它们之间不免会有交集,而这,也仅仅限于代码编写时,在运行时,每一个Ability都有本身的进程和内存空间。

3. 根据设备

  • 1). 单设备
  • 2). 跨设备

鸿蒙OS天生具备链接多设备的能力,而对于开发者来讲,须要考虑的是当前环境下有多少已经链接的设备,而不是要去链接哪台设备。

具体的说,就是,咱们不须要考虑网络的问题,而是要考虑,在当前环境中,用哪一个设备来完成任务更合理。

有多设备环境下的分布式Hello Harmony,

* 能够每台设备轮流说Hello Harmony,即你说Hello Harmony,我也说Hello Harmony。
* 也能够全部设备一块儿完成一个Hello Harmony,即你说Hello 我说 Harmony。

参考文档

* Ability 概述
> https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ability-ability-overview-0000000000029852
* 分布式任务调度
> https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ability-distributed-overview-0000001050419345

后续

接下来,我将对不一样的写法,一一进行讲解,欢迎持续关注。

做者:IT男阿斌
想了解更多内容,请访问: 51CTO和华为官方战略合做共建的鸿蒙技术社区https://harmonyos.51cto.com

【免费直播公开课-HarmonyOS驱动框架调试总结】

相关文章
相关标签/搜索