当前位置: 首页 > news >正文

对openharmony HDF驱动框架的C/S设计模式和单例类的说明

在分析openharmony的HDF驱动框架时我们会发现用了很多面向对象的思想,例如类继承、接口、单例类等,本来应该是好事情,**但使用时对象之间的关系交错复杂,不太符合linux内核分层分模块的思路,导致整体理解起来比较困难,**再加上"C/S设计模式”和“观察者设计模式"更导致系统理解起来比较麻烦,本文便针对C/S设计模式和单例类这个问题做梳理。

C/S设计模式和单例类

通过对HDF框架的梳理我们可以得到下图的关系,我们可以看到几个关键的代码块(Block),例如设备管理者服务(DevmgrService)、设备服务管理者(DevSvcManager)以及设备宿主服务(DevHostService)都有客户端、接口、实例主体这三个角色相关联。本文的目的是介绍此种方法的"道"而非"术"(在总结一篇术的文章,但是篇幅巨大,没法看,只能一点一点的先拆成一部分一部分的),所以只会单拎出一个代码块来进行说明,让大家了解这种应用方法。
在这里插入图片描述✒️上图中设备宿主服务并没有使用单例模式,业务上此对象时需要建立多个的,放在此处主要为了说明C/S这种模式。

下面单独针对设备管理者服务(DevmgrService)进行说明

通过对代码的梳理可得代码流程如下图所示,由此可知此函数DevmgrServiceGetInstance的作用为创建DevMgr单实例对象,并为此对象设置好了具体的实现方法

在这里插入图片描述

为了更好的观察DevMgr实例的具体方法我们可以参看IDevmgrService对象的类图,由图中标号①与标号②中我们可以发现实际创建的对象为单实例的DevmgrService类型(采用的static类型的对象),而接收的对象(即返回值,标号②处)为IDevmgrService类型,由下面类图中的结构可知返回IDevmgrService类型相当于返回的单实例对象DevmgrService的super成员,可直接使用对应的接口函数
在这里插入图片描述
**在驱动框架需要使用DevmgrService提供对应的服务时,可通过DevmgrServiceClntGetInstance函数获取设备服务管理客户端(DevmgrServiceClnt)的实例,该实例包含一个指向IDevmgrService对象的指针,通过该指针可以使用DevmgrService提供的服务,即设备管理接口。**客户端可以调用设备管理服务提供的功能,即C/S设计模式。

在分析时可能有码友会有一个困惑,当客户端的成员变量只有一个接口对象时,获取的对象又为单实例,此次返回的实际就是设备管理者服务(DevmgrService)实例本身,两者获取的函数几乎相同(如下图),那**为何不直接调用服务本身呢?**例如直接舍弃DevmgrServiceClnt,直接使用DevmgrService。
在这里插入图片描述

关于这个问题我们相信如果直接使用DevmgrService本身应该也是可以实现的,但是职责不够清晰,扩展性差。通过下图(左边客户端,服务本身)来看他们分别提供的方法
在这里插入图片描述

DevmgrServiceClnt提供的方法如下:

  1. DevmgrServiceClntAttachDevice:将设备(通过IHdfDeviceToken接口表示)附加到设备管理服务中。这通常意味着在系统中注册设备,使其可被管理和使用。
  2. DevmgrServiceClntDetachDevice:从设备管理服务中分离(注销)指定设备ID的设备。
  3. DevmgrServiceClntAttachDeviceHost:将一个设备主机(通过IDevHostService接口表示)和主机ID附加到设备管理服务中。设备主机可能是一个硬件或软件组件,负责一组设备的通信和管理。

而DevmgrService提供的方法如下:

  1. DevmgrServiceStartService:启动设备管理服务,使其开始监听和处理设备相关的请求。
  2. DevmgrServiceConstruct:构造(初始化)设备管理服务实例。这个函数会分配必要的资源、初始化接口等。
  3. DevmgrServiceCreate:创建一个设备管理服务的实例。这个函数会返回一个HdfObject类型的对象,这是一个通用的对象框架,用于HDF(Hardware Driver Foundation)系统中的对象管理。
  4. DevmgrServiceRelease:释放设备管理服务实例,进行资源清理。
  5. DevmgrServiceGetInstance:获取设备管理服务的实例。
  6. DevmgrServiceLoadLeftDriver:加载驱动程序。

由上可得出客户端主要是为了实现Manager域与Host域(设备)之间的有效通信和管理,而服务主体主要是实现对服务本身的管理。

相关文章:

  • 【设计模式】-工厂模式(简单工厂、工厂方法、抽象工厂)
  • flask和django的对比
  • ECCV2022 | LGV | LGV:利用大几何邻域提升对抗样本的可迁移性
  • Vue2组件通信
  • 工作流改造:从一到千
  • 网络安全用centos干嘛 网络安全需要学linux吗
  • DBSCAN 基于密度的空间带噪聚类法
  • LM Studio纯CPU运行大模型不如ollama效率高
  • jenkins服务启动-排错
  • 数组_二分查找
  • Android-构建问题记录
  • Java版PDF拼接
  • 配查查:解锁商业奥秘,赋能智慧决策
  • OpenEuler学习笔记(三十二):在OpenEuler上搭建项目管理平台
  • django静态文件配置
  • Neo4j OGM学习和体验
  • Linux中安装open-webui报sqlite版本低的解决办法
  • 【React组件通讯双重视角】函数式 vs 类式开发指南
  • 第二章:基础概念精讲 - 第二节 - Tailwind CSS 颜色系统和主题定制
  • 什么是环形分区光源
  • 不赚“快钱”的佳沛:蒋时杰解密新西兰国果如何在中国“慢养”出43亿生意
  • 魔都眼|邮轮港国际帆船赛启动,120名中外选手展开角逐
  • 哈马斯与以色列在多哈举行新一轮加沙停火谈判
  • 上海公办小学验证今起开始,下周一和周二分区进行民办摇号
  • 湖南慈利一村干部用AI生成通知并擅自发布,乡纪委立案
  • 韧性十足的中国外贸企业:“不倒翁”被摁下去,还会再弹起来