首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

XPCOM指南-一_XPCOM概述

2013-12-11 
XPCOM指南-1_XPCOM概述XPCOM概览本章为XPCOM的快速导览,对XPCOM和组件开发的基础思想和技术做了说明,这些

XPCOM指南-1_XPCOM概述


XPCOM概览

本章为XPCOM的快速导览,对XPCOM和组件开发的基础思想和技术做了说明,这些说明从较高层次来描述的,只是为了熟悉一下本指南需要的一些背景知识。

1. XPCOM 解决方案
XPCOM ( Cross Platform Component Object Model),是一个跨平台的软件框架,它使开发人员把一个大的软件工程分解成各个小的独立的模块,然后再运行时再组装在一起,这就是组件化的思想。

XPCOM的目标是让不同开发者独立开发实现相应的软件片段(组件)。 为了解决应用程序里各组件之间的互连问题,XPCOM把组件的实现和接口分离开来(相关主题在 Interface[https://developer.mozilla.org/en-US/docs/Creating_XPCOM_Components/An_Overview_of_XPCOM#Interfaces] 章节讨论),XPCOM也提供了几个工具和库,以便加载和维护这些组件,服务,帮助开发者写模块化的跨平台的代码和版本支持,因此组件可以进行不中断替换和升级。 使用XPCOM,开发者创建的组件可以在不同的应用程序里重用。

XPCOM不仅仅支持组件化软件开发,他也提供了很多开发平台提供的功能,例如:
组件管理 ( component management )抽象文件 ( file abstraction )对象消息传输 ( object message passing )内存管理 ( Memory management )
我们会在下面的章节对上面列表项的细节进行讨论,XPCOM作为一个组件开发平台,这些功能是很有必要的。


2. Gecko尽管XPCOM在某些方面与Microsoft COM相似,但是她主要还是被设计为应用级别。 在Gecko里XPCOM得到了最重要的应用,Gecko是一个开源的,符合标准的,嵌入式Web浏览器和工具包,可以通过Gecko创建Web 浏览器和其他应用。

XPCOM提供了访问Gecko库的方法,并且可以对Gecko进行扩展,甚至把Gecko嵌入到其他程序。本指南主要聚焦Gecko的扩展,但是用到的一些方法同样适用于Gecko的嵌入使用。

Gecko被用于很多internet应用程序,主要是浏览器,最重要的一个例子就是 Mozilla Firefox。

3. 组件XPCOM可以让你把大型的软件项目分割成各个独立的组件。 他们通常包含在可重用的二进制库里(windows下的DLL,或者UNIX下的DSO),这些二进制库可以包含一个或多个组件。当两个或更多地组件作为一个组放入二进制库时,我们通常把这个库叫做模块。

模块化,基于组件的编程模式使得开发和维护软件更佳容易,他包含了下列众多优点:
重用,模块化的代码可以在其它应用程序进行使用更新,你可以更新组件而不需要重新编译整个应用性能,当程序采用了模块化的结构,对于不需要立即使用的模块,可以采用"lazy loaded",或者不加载,这样可以提高程序的性能。维护,
Mozilla包含的代码已经超过了4000000行,单独一个人是没法全部弄明白的。 处理这种规模的最好的方式是把他划分成更小的,更易于管理的部分,使用组件编程模型,并把相关的组件作为一个模块。例如网络库,组成组件的协议,HTTP,FTP和其他协议,被打包到一起,链接成一个单一的库。 这个库就是网络模块,叫做"necko"。

但划分并不总是一个好主意。在这个世界上有些事情,只能在一起,不应该被分开。例如,一个作者的儿子不会吃没有果酱的花生酱三明治,因为在他的世界里,花生酱和果酱在一起才是花生酱三明治。有些软件是一样的,代码是紧密耦合的类,只在内部使用,例如昂贵的工作划分的事情,可能是不值得的努力。

Gecko里的HTTP组件作为一个单独的组件,不会暴漏他的私有类。 组件内部东西依然只是组件内部使用,不会暴漏给XPCOM。 在Mozilla早期开发中,因为太匆忙,一些组件的划分和创建不太合适,但是这些在以后的持续开发中会不断的消除掉。

4. 接口( Interfaces )那么怎么把程序划分为一个个组件呢? 最基本的思想就是先按照功能划分,然后弄清楚各个功能之间关系,了解他们之间怎么进行通信。 不同组件之间的交互通道就可以作为划分这些组件之间的边界。 我们给这些确定的边界一个名称:接口。

接口在编程里并不是一个新事物。 其实我们的第一个"Hello World"程序就用到了接口,这个接口就是代码和真实的写操作直接的边界 -- 程序代码 -- 和打印代码。 程序代码使用 stdio库提供的接口,在屏幕上打印出"Hello World"。"Hello World"程序和XPCOM的不同点在于,XPCOM是在运行时发现屏幕打印功能,而 stdio 库是在编译时。

接口可以让开发者封装软件内部工作的实现,让客户不必关心功能怎样实现,而只是使用这个软件。

接口和契约式编程(Interface and Programming by Contract)

一个接口就是组件和客户端之间的契约。 没有代码强迫执行这个契约,但是忽略他们可能是致命的。在组件化编程中,
组件应该确保它提供的接口是不可变的(他们会在不同的版本里针对相同的方法提供相同的访问方式)建立一个契约。在这
方面,基于接口的编程通常被称为契约是编程。

4.1 接口和封装在组件边界之间,抽象对于软件的可维护和重用性是决定性因素。 思考下面的例子,一个类没有进行封装。 使用可
随便使用的Public类别的初始化方法,如下面代码所示,会引起问题。

SomeClass 类初始化

NS_IMETHOD方法申明的返回类型. XPCOM method declarations should use this as their return type.NS_IMETHODIMP方法实现的返回类型. XPCOM method implementations should use this as their return type.NS_IMETHODIMP_(type) 指定方法实现的返回类型. Some methods such as AddRef and Release do not return the default return type. This exception is regrettable, but required for COM compliance.NS_IMPORT Forces the method to be resolved internally by the shared library.NS_EXPORT Forces the method to be exported by the shared library.


8.2 Reference Counting
下面的宏用于管理引用计数。

NS_ADDREF Calls AddRef on an nsISupports object.NS_IF_ADDREF
 Same as above but checks for null before calling AddRef.NS_RELEASE Calls Release on an nsISupports object.NS_IF_RELEASE Same as above but check for null before calling Release.
8.3 Status Codes下面的宏用于测试状态码。

NS_FAILED Return true if the passed status code was a failure.
NS_SUCCEEDED Returns true is the passed status code was a success.

8.4 Variable Mappingsnsrefcnt Default reference count type. Maps to a 32-bit integer.
nsresult Default error type. Maps to a 32-bit integer.
nsnull Default null value.

8.5 Common XPCOM Error CodesNS_ERROR_NOT_INITIALIZED Returned when an instance is not initialized.
NS_ERROR_ALREADY_INITIALIZED Returned when an instance is already initialized.
NS_ERROR_NOT_IMPLEMENTED Returned by an unimplemented method.
NS_ERROR_NO_INTERFACE Returned when a given interface is not supported.
NS_ERROR_NULL_POINTER Returned when a valid pointer is found to be nsnull.
NS_ERROR_FAILURE Returned when a method fails. Generic error case.
NS_ERROR_UNEXPECTED Returned when an unexpected error occurs.
NS_ERROR_OUT_OF_MEMORY Returned when a memory allocation fails.
NS_ERROR_FACTORY_NOT_REGISTERED Returned when a requested class is not registered.

热点排行