BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Google单实例模式检测工具

| 作者 Geoffrey Wiseman 关注 0 他的粉丝 ,译者 张海龙 关注 0 他的粉丝 发布于 2007年8月14日. 估计阅读时间: 2 分钟 | CNUTCon 了解国内外一线大厂50+智能运维最新实践案例。
Google发布了一个单实例模式检测工具,通过执行字节代码检查以定位和报告字节代码中存在的单实例对象。尽管单实例模式是一种常用的软件模式,但许多人对其存有争议,需要小心地使用:这些争论可以分为支持反对两个方面。如一个项目的wiki上所写:
单实例模式的问题在于,它的状态对于程序来讲是全局性的,允许任何人随时存取而忽略了范围。更糟糕的是,单实例模式是现今被过分使用的一种设计模式,许多人在完全不必要的情况下就在实例中使用了这种可能带来不利的全局状态。
程序使用全局状态时是很难进行测试的……当一个类使用单实例模式时(我是在谈论类的单实例模式,即通过强制使用静态的getInstance()方法得到单实例的类),单实例模式的使用者和此单实例的类会无可避免地耦合在一起。
依赖于静态实例意味着这些方法的声明无法显示出它们的依赖关系,因为这些方法会让单一模式的使用难上加难,也就是说用户必须了解其内在的工作代码才能正确地使用它,这让使用和测试它变得很困难。
当测试人员测试一些方法时,如果它们依赖于单实例的类,那么它们的依赖关系就变得很不明确,测试人员就可能在不知情的情况下写出由于修改共享资源而造成相互依赖的两个测试类。

Google单实例模式检查工具可以检查出那些强制使用自身的单实例的类(单实例,singleton),或是帮助另外一个类强制实现其单实例化的类(帮助者单实例,或称之为“hingleton”),或是通过一个不带参数的静态方法返回其状态(方法单实例,或称之为“mingleton”)的,或是有一个公开的静态字段(字段单实例,或称之为“fingletone”)的类,以及那些依赖于以上任一种单实例类的代码。你可以隐藏掉那些你不关心的行为。

这个工具目前还处在早期阶段,有如下一些限制

  • 在没有解开多JAR包以前,它无法读取字节码。
  • 它需要一个外部工具显示图形结果。
  • 它并不能发现所有的单实例对象,尤其是那些存储在final型字段和封装于内部类中的单实例对象。
继续关注InfoQ,将会得到更多关于代码分析构件和工具Google的信息。

查看英文原文Google Singleton Detector

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT