XPCOM指南_7结束编写WebLock.docVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
XPCOM指南_7结束编写WebLock

现在您已创建组件的大多数基础结构。 该组件可以被XPCOM和类别管理器识别,那样在 XPCOM初始化时,它就可以开启动。 组件启动时,它会读取存储在本地文件系统里Url列表,填充到相应的二进制结构。 Using Frozen Interfaces 然而,现在阻止站点的核心功能仍然缺失。 这个接口仍然没有冻结,组件开发人员需要讨论那些功能应该完全公开,所以API没有准备好发布。 这让你处于和大多数使用Mozilla的开发者一样的境地—你想使用一些特定的功能,但是接口似乎天天都在变。 所有的Mozilla的源代码是公开的,并且接口使用也很容易。 抓一个合适的头文件,使用组件或者服务管理器访问你需要的接口和XPCOM对象,实现你将会在你的项目里实现的接口。 这带来了很大的灵活性,当然你会失去一些兼容性。 如果你使用没有冻结的“东西”,那个东西将来可能随着Gecko的版本变化而变化。 如果你想你的组件能够对来自Gecko的变化免疫,你必须只使用已经冻结的接口和APIs。 一般这会在接口申明上面的进行说明。 例如,下面的nsIServiceManager: /** * The nsIServiceManager manager interface provides a means to obtain * global services in an application. The service manager depends * on the repository to find and instantiate factories to obtain * services. * * Users of the service manager must first obtain a pointer to the * global service manager by calling NS_GetServiceManager. After that, * they can request specific services by calling GetService. * When they are finished they can NS_RELEASE() the service as usual. * * A user of a service may keep references to particular services * indefinitely and only must call Release when it shuts down. * * @status FROZEN */ 冻结的接口和函数时GECKO SDK的一部分。 有一个经验,SDK外部的接口可当作是“实验性”的或者未冻结的。 参见侧边拦的信息,它描述了冻结或未冻结的接口怎么影响你的软件开发,它还包括了接口变化会导致严重破坏的一些技术细节。 使用未冻结接口的危险性 假设你在您的组件里使用了未冻结的接口,nsIFoo,这个接口在你测试时使用的那个版本的Gecko很正常。 然而在将来某个时候,nsIFoo有了重大变化,它的方法重新排序,添加,删除了一些。 此外,这个接口不应???被其它的Gecko或Mozilla客户使用,接口的维护人员也不知道有其它的开发者使用了这个接口,他并不会改变接口的IID。 当你的组件在此新版本的Gecko里运行时,你的方法调用将会通过不是你期望的虚表(v-table)路由,这将会产生一个不可预期的结果,甚至导致崩溃。 看下面的图,组件编译时使用的nsIFoo接口有三个方法。 组件调用TestA方法,传入一个整数10。 这个可以在任何如编译时使用的相同版本的Gecko的应用上正常运行。 然而当nsIFoo接口发生了变化,TestA方法被删除了;虚表里的第一个函数现在成为了IsPrime()。 当组件调用TestA时,实际上它是调用的方法IsPrime。 不用说,这很不爽。 此外,还没有一种方式,容易的方式来发现这种类型的运行时错误。 Gecko的开发人员可以更改该接口的IID,和一些其它工作。这可以防止很多类似错误。但未冻结的接口不提供任何正式方式支持,和为接口的任何变化提供不同的IID接口并不是一个好主意。 当使用冻结的接口,你就不用担心以后Gecko版本变化会带来兼容性问题。 唯一的问题是,编译器的变化,导致虚表的布局的变化,这种变化只在编译器的ABI变化是会发生。 例如,2002年的GCC 3.2改变了C++的ABI,这将会影响所有用GCC3.2编译的应用程序。 相应的问题在GCC 4.0时也发生过。 在你使用未冻结的接口之前,你应该联系负责你使用的代码的开发者,问问他。 他们可能会建议你是否使用这

您可能关注的文档

文档评论(0)

185****7617 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档