#夏日挑战赛# OpenHarmony 实现的一个IPC的客户端和服务端(L2) 原创 精华
@toc
简介
挺长时间没接触L2的设备开发,再看OpenHarmony3.1代码时候,发现3.1与3.0相比:
编译的ohos.build已经去掉,取而代之的是bundle.json,有的目录结构也发生了变化。
此文档:OpenHarmony 3.1代码基础。
- 3.1的编译配置(与3.0比,有些调整)
- IPC动态库服务端工程。
- IPC客户端。
- safwk加载动态库服务端。
- 客户端和服务端的通信.
想对IPC通信了解深入,可以结合下面两篇文章和代码一起分析学习:
OpenHarmony IPC通信(L2)
OpenHarmony SA 动态库服务 拉起的main入口 - 本用例开发板(3516开发板:HiSpark_AI_Hi3516D_One_Light_VER.B开发板上测试)
编译配置
子系统配置
build\subsystem_config.json
"myapp": {
"path":"myapp",
"name": "myapp"
}
产品配置
productdefine\common\products\Hi3516DV300.json
"myapp:myappservice_test":{}
注意:3.2beta2去掉了3516,类似此配置的文件为vendor\hihope\rk3568\config.json(以dayun200为例)
{
"subsystem": "myapp",
"components": [
{
"component": "myappservice_test"
}
]
}
编译配置
myapp\myappservice\bundle.json
myapp\myappservice\BUILD.gn
代码
代码目录结构
myapp的代码见附件
,关键部分有注释,方便对IPC交互的了解。
服务ID的添加
服务ID有统一的头文件
foundation\distributedschedule\samgr\interfaces\innerkits\samgr_proxy\include\system_ability_definition.h
MY_APP_SERVICE_ID = 9000,
...
{ MY_APP_SERVICE_ID, "MyAppService"},
编译
要全量编译9000.xml 才能生产myappservice_sa.xml
编译命令:./build.sh --product-name Hi3516DV300 --ccache
修改开发板的读写权限
进入终端:hdc_std.exe shell
修改权限:mount -o remount,rw /
添加test目录:mkdir /data/test/
将编译文件发送到开发板对应目录:
修改客户端可执行权限
切到对应的目录:cd /data/test/
修改成可执行:chmod 0755 myappclient
测试
终端1:抓取日志
终端2:启动服务
sa_main /system/profile/myappservice_sa.xml
终端3:启动客户端
/data/test/myappclient
下图是客户端和服务端的交互输出结果。
注意:hdc_std.exe工具,如果3.1的编译不能连接设备。可以试一下最新主干代码来编译hdc工具。
编译命令:./build.sh --product-name ohos-sdk --ccache
,参考developtools_hdc
666
好文章,赞起!
老师又一篇好文,不错呀