OpenHarmony分布式软总线子系统

OpenHarmony分布式软总线子系统

简介

分布式软总线子系统旨在为OpenHarmony系统提供的通信相关的能力,包括:WLAN服务能力、蓝牙服务能力、软总线、进程间通信RPC(Remote Procedure Call)等通信能力。

WLAN服务:为用户提供WLAN基础功能、P2P(peer-to-peer)功能和WLAN消息通知的相应服务,让应用可以通过WLAN和其他设备互联互通。

蓝牙服务:为应用提供传统蓝牙以及低功耗蓝牙相关功能和服务。

软总线:为应用和系统提供近场设备间分布式通信的能力,提供不区分通信方式的设备发现,连接,组网和传输功能。

进程间通信:提供不区分设备内或设备间的进程间通信能力。

系统架构

图 1 分布式软总线子系统架构图

目录

分布式软总线子系统主要代码目录结构如下:

复制代码
/foundation/communication
├── bluetooth       # 蓝牙功能代码
├── dsoftbus        # 软总线功能代码
├── ipc             # 进程间通信代码
└── wifi            # WLAN功能代码

约束

  • 组网限制:必须确保设备在同一个局域网中。

使用说明

进程间通信

在使用RPC时,请求服务的一端进程可获取提供服务一端所在进程的代理 (Proxy),并通过此代理读写数据来实现进程间的数据通信,其详细过程如下:

  1. 实现服务端及其提供的能力。
  2. 请求服务的一端会建立一个服务提供端的代理对象,这个代理对象具备和服务提供端一样的功能,若想访问服务提供端中的某个方法,只需要访问代理对象中对应的方法即可。
  3. 服务提供端处理接收到的请求,处理完之后通过驱动返回处理结果给代理对象。
  4. 代理对象将请求结果进一步返回给请求服务端。

软总线

  • 组网
  1. 服务启动之后,获取已经在线的设备列表。
  2. 注册上下线监听,通过回调通知感知设备列表变化。
  3. 获取设备的Id、设备名称、设备类型。
  4. 获取指定设备的设备类型,组网类型,设备能力等更多信息。
  5. 进程退出时,删除上下线监听。
  • 传输
  1. 根据Socket名称,调用者包名等信息,创建Socket。
  2. 服务端启动监听,客户端进行绑定。
  3. 绑定成功,可发送数据。
  4. 待Socket不使用时,关闭Socket。

相关仓

分布式软总线子系统

communication_bluetooth

communication_dsoftbus

communication_ipc

communication_wifi

相关推荐
心走1 小时前
鸿蒙WebRTC编译指南&踩坑(Native 编译指导)
harmonyos·音视频开发
冯志浩3 小时前
HarmonyOS - 嵌套类属性状态管理装饰器:ObservedV2 和 Trace
harmonyos·掘金·金石计划
塞尔维亚大汉5 小时前
【鸿蒙南向开发】OpenHarmony小型系统内核(LiteOS-A)【文件系统】下
物联网·嵌入式·harmonyos
智驾7 小时前
什么是鸿蒙南向开发?什么是北向开发?
harmonyos·南向开发·北向开发
周胡杰7 小时前
weibo_har鸿蒙微博分享,单例二次封装,鸿蒙微博,微博登录
华为·harmonyos
塞尔维亚大汉7 小时前
【鸿蒙南向开发】OpenHarmony小型系统内核(LiteOS-A)【扩展组件】下
物联网·嵌入式·harmonyos
智驾9 小时前
Openharmony 和 HarmonyOS 区别?
harmonyos·openharmony
别说我什么都不会9 小时前
【仓颉三方库】工具类——zip4cj & zlib4cj
harmonyos
高木的小天才21 小时前
鸿蒙中的并发线程间通信、线程间通信对象
前端·华为·typescript·harmonyos
脑极体1 天前
开源鸿蒙,给机器人带来了什么?
华为·机器人·开源·harmonyos