0 引言 在软件开发中,组件是一些小的二进制可执行程序,它们可以给应用程序、操作系统以及其他组件提供服务。实际应用中主要采用COM技术开发软件组件。这是由Microsoft提出的一种组件标准,它定义了组件程序之间进行交互的标准。标准的COM技术主要用于Microsoft Windows平台,是windows操作系统和各种应用软件的结构基础,其突出优点是软件之间直接通过二进制接口进行通讯。
开发自定义的COM组件就如同开发动态的、面向对象的API。多个COM对象可以链接起来形成应用程序或组件系统。组件可以在运行时刻,并在不被重新链接或编译应用程序的情况下被卸下或替换掉。
要实现基于COM标准的跨平台轻量级组件,需要满足三个条件:
一是源代码级跨平台,可以在LINUX和WINDOWS上使用;
二是像容器一样的管理组件DLL/SO;
三是功能组件化。
在工控系统组态过程中,通常存在着人际界面软件开发周期长,维护困难,升级不便等缺点,为了增强组态软件的行业竞争力,希望从软件开发模式上改变当前系统软件的缺陷,同时为了适应系统软件跨平台的需要,根据COM标准组件技术,并结合QT、以及组态人机界面软件自身的特点,可以实现轻量级组件技术。本文所述的轻量级组件技术就是以COM标准为基础的,并根据实际的应用环境做了某些改变。
1 轻量级组件各部分的协作关系
跨平台轻量级组件技术可以COM标准为基础来实现,可先定制Com库,并确定编写组件的规范。
轻量级组件技术使用的是分层结构,该结构通常可分为客户端、Com库、组件端三个层。图1所示是其轻量级组件的结构图。其中,组件端用于提供功能和接口;COM库负责组件和客户端的通信,客户端则通过Com库创建组件,并调用组件接口。
它们三部分一般通过接口进行通信,其具体过程如图2所示。
在实际应用中,Com库一般可由图3所示两部分构成。实际上,图3中的Comku是一个动态库,负责提供最核心的功能:ExtensiONSySTem静态库是对Comku的封装,为了使用方便,它同时提供了生成插件接口的宏以及CPluginManager类中的接口函数。下文中如不特别指明,Com库均表示单一的动态库。
整个组态的人机界面软件是在QT中实现的,因此组件的核心库也需要使用QT来实现。QT是一个多平台的C++图形用户界面应用程序框架。它可以提供给应用程序开发者建立艺术级的图形用户界面所需的所有功能。QT是完全面向对象的、很容易扩展、且可支持源代码的级跨平台。直接在QT环境中实现轻量级组件技术,以达到跨平台的目的。实际上,组件库本身并不依赖于QT环境。
2 Com库的原理及功能
对于使用了轻量级组件技术的应用程序,Com库主要用来管理插件DLL、创建和销毁组件指针,它像容器一样,可以保存当前应用程序中用到的插件信息和接口信息,并在用户需要的时候返回正确的插件接口指针。
2.1 管理组件的功能
Com库中可维护两个链表,分别用于存放插件DLL的信息和接口信息。
每次使用Com库加载的DLL信息都将记录到插件链表中。在为用户创建接口前,还需要查询插件链表,以判断该插件是否已经被加载,如已加载,便可直接使用,不需要重新加载,这样可以节省系统开销。由于在应用中加载的插件数目有限,因此,查询链表花费的时间代价可以忽略,图4所示为存放插件信息的结构。其中CLASS_TABLE结构存放插件DLL的信息。接口链表可用来保存成功返回给用户的插件接口。用户申请接口时,Com库先在接口链表中查找该接口,如果已经存在,则直接返回,这样可以节省创建接口的时间,也可以有效地控制接口对象的数目。
图5所示是CIMPL结构用于存放插件接口的信息。
释放这两个链表的过程就是释放组件资源的过程。在COM标准中,资源管理是通过一个由接口自己负责的资源计数器完成的。在轻量级组件技术中,根据应用需要,每个接口只需要一个接口指针,而不需要资源计数器,释放资源的任务由Com库完成。当应用程序关闭时,可将两个资源链表中的接口对象删除,并将组件DLL/SO卸载。
2.2 创建插件接口指针
Com库的核心功能就是创建组件接口指针。
创建组件接口指针的函数为CoCreateInstance,它具有图6所示的三个参数。其创建过程如图7所示。
2.3 ExtensionSystem静态库
ExtensionSystem静态库中已加载了Com库,并将Com库的创建接口指针函数封装成接口。这样,客户端在使用时,就不需要关注Com库的具体位置,而可以直接调用ExtensionSystem的接口来获取插件接口指针。
2.4 配置文件
配置文件主要用来标识当前程序所需要加载的组件,以及组件的位置。配置文件可分为两部分:
第一部分用于标识加载的组件和加载顺序;第二部分用于标识组件的位置。图8所示是配置文件的信息示意图。
DLL/SO组件编写规则
轻量级组件技术要求组件DLL/SO应按照约定的格式编写,只有组件库加载后,才能为客户端创建组件接口指针。
一个类似于IUnknown的基接口,通常是所有接口都需要继承的,其代码如下:
Release函数可用来释放组件接口对象。
每个DU/SO中都需要有一个类实现IPlugin接口,该类称为组件类,Init函数在ExtensionSysten中被调用时,可以在其中完成组件的初始化工作,其具体代码如下:
每个组件DLL/SO都需要导出一个创建接口的函数,形式如下:
4 结束语
QT本身提供有插件机制,但是,加载方式对用户是不可见的,因此,出现问题后,往往不利于调试。而本文所述的组件编写方式和加载方式使用约定的形式,这种形式并不局限于QT中,而是在支持标准c++的编译环境中都可以使用,因而是一种通用的轻量级组件技术。
发表评论
-
c语言中的字符数组与字符串
2012-07-06 09:51 8811、字符数组的定义 ... -
打造自己的正则表达式助手程序
2012-07-06 09:45 699原文地址:http://ire ... -
正则表达式
2012-07-06 09:37 755正则表达式 字 ... -
swing look and feel demo
2012-07-06 09:30 649more information : http://cid ... -
一个简单的仿sohu电视剧播放列表[脚本]
2012-07-05 20:45 619实例下载地址:http://download.csdn.n ... -
PHP作为Flex程序的数据源
2012-07-02 10:28 566Adobe Flash Builder 4 简体中文正式版 ... -
Flex 遍历组件的实现
2012-07-02 10:28 754Flex有两个阵营组件:spark组件和mx组件,关于sp ... -
Flex + BlazeDS 学习笔记 (一) --- BlazeDS的功能原理及配置实例
2012-07-02 10:27 545BlazeDS Test Drive里面示例了主要的功能: ... -
java与flex通信
2012-07-02 10:27 658一、准备: 服务端:JDK1.5 (这个不用介绍了吧 ... -
Flex Image加载Servlet图像流处理
2012-07-01 00:04 420Image控件是Flex加载、显示图像的一个控件,当然其也 ... -
Flex初始化时加载外部XML
2012-07-01 00:04 696Flex初始化时加载外部XML配置文件 Flex项目 ... -
Flex动态加载swc和swf中的class
2012-07-01 00:04 639flex中比较少人使用相关的反射,主要原因是因为avm编译 ... -
视频聊天网站的研究、发展以及趋势(转)
2012-07-01 00:03 508此文讲述了视频聊 ... -
视频聊天网站的研究、发展以及趋势(转) ...
2012-07-01 00:03 555此文讲述了视频文件聊天网站相干的技术、发展过程和将来的发展 ...
相关推荐
标题中的“一款基于Netty+Zookeeper+Spring实现的轻量级Java RPC框架”揭示了这个项目的核心技术栈,它整合了三个在分布式系统中广泛使用的开源库:Netty、Zookeeper和Spring。让我们逐一深入探讨这三个技术以及它们...
《轻量级工作流引擎的设计与实现》是一篇深度探讨工作流引擎技术的文献,尤其适合在设计阶段作为指导。工作流引擎是自动化业务流程的关键工具,它在各种规模的企业和组织中扮演着不可或缺的角色。本文主要关注轻量级...
JTaro是一个专为Vue 2.0设计的轻量级H5单页应用(SPA)框架,它旨在简化H5应用程序的开发流程,提供高效、易用的开发体验。Vue.js是一个非常流行的前端JavaScript框架,以其简洁的API和组件化开发模式而闻名,JTaro...
1. **轻量级设计**:此源码设计时考虑了性能和效率,采用了轻量级的架构,降低了服务器负载,保证了用户在访问和播放视频时的流畅体验。 2. **影视资源搜索**:源码内置了搜索功能,能够对接不同的资源网,使用户...
ATL,即**活动模板库**(Active Template Library),是一种专为C++开发者设计的轻量级库,旨在简化COM(Component Object Model,组件对象模型)对象的开发流程。相较于其他更为复杂且功能全面的框架(例如MFC),...
《轻量级Java EE企业应用实战(第三版)》是由著名IT专家李刚撰写的一本经典书籍,专注于讲解如何在企业环境中高效地运用Java EE技术。这本书的第一部分为我们揭示了Java EE开发的核心概念和实践技巧,是理解轻量级...
基于关系结构的轻量级工作流引擎就是这样的一个尝试,它利用关系数据库的强大功能,实现了工作流的管理和执行。 1.1 关系结构的优势 关系结构是数据库管理的基础,具有数据一致性、可扩展性和查询效率高等特点。在...
x-spreadsheet-master是一款基于JavaScript的开源在线表格组件,利用HTML5的canvas技术进行绘制,提供了一种轻量级且高效的数据编辑和展示解决方案。Canvas作为HTML5的一个重要元素,允许开发者在网页上动态渲染图形...
标题:“Spring轻量级与EJB重量级容器的比较” 描述:“我自己做的第一个文档” 标签:“容器” 部分内容:本文档旨在深入探讨Spring轻量级容器与EJB重量级容器的区别,通过对这两个概念的剖析,帮助读者理解它们...
### 基于轻量级J2EE框架的网络教学系统 #### 一、引言 随着信息技术的快速发展,网络教育已经成为现代教育体系中的一个重要组成部分。然而,当前大多数网络教学系统都建立在Wintel(Windows操作系统和Intel CPU)...
在React开发中,轻量级组件是一个重要的设计概念,它强调了代码的模块化和可重用性。React Suspense 和 GraphQL API 的结合则为现代Web应用提供了强大的数据获取和渲染解决方案。这篇讨论将深入探讨这两个关键技术...
《iris:基于ØMQ的轻量级组件模型与消息传递框架深度解析》 在现代软件开发中,组件化和高效的消息传递是提升系统灵活性、可扩展性和可维护性的重要手段。iris框架,作为一款基于ØMQ(ZeroMQ)的轻量级组件模型,...
MySQL作为数据库管理系统,是轻量级小博客CMS的核心组件。MySQL以其高性能、高可靠性和良好的扩展性而广受青睐。在这个系统中,MySQL存储博客文章、用户信息、评论等数据,通过SQL语句进行数据的增删改查操作。...
- **大数据处理平台**:虽然轻量级J2EE框架主要用于构建Web应用,但结合Spring Batch等组件也能支持一定规模的大数据处理需求。 #### 五、总结 《轻量级J2EE企业应用实战第三版》是一本非常实用的技术书籍,不仅...
今天我们将深入探讨一款基于PHP的lyadmin轻量级通用后台源码,了解其设计理念、核心功能及其实现方式。 lyadmin是一个专门为中小型项目设计的轻量级后台管理系统,它以简洁、快速、高效为特点,旨在帮助开发者快速...
【标题】"基于 Naive UI 的轻量级后台管理模板源码"是一个使用Naive UI框架构建的简单、高效的后台管理系统界面模板。Naive UI 是一个由 Vue.js 驱动的组件库,专为现代 Web 应用设计,提供了一系列可复用且易于定制...
本资源提供的是一个基于C#实现的轻量级ORM类库源代码,对于理解和学习ORM工作原理,以及自定义ORM实现具有很高的参考价值。 在C#中,ORM类库如Entity Framework、NHibernate等,它们能够帮助开发者将数据库表与C#类...
基于注解的轻量级Java流程跟踪工具提供了一种简单而高效的方式来监控和记录程序执行过程,使得问题定位更加方便。下面我们将深入探讨这个话题。 首先,注解(Annotation)是Java 5引入的一种元数据机制,它允许...
《轻量级Java EE企业应用实战(第三版)》是一本深入浅出的教程,主要针对Java EE技术在实际企业应用中的轻量化解决方案。这本书的第十章内容虽然被压缩包包含,但整体书籍覆盖的范围可能更为广泛。下面将根据章节...