作者:朱金灿
来源:http://blog.csdn.net/clever101
代码中有这样一个类:
class DLL_SYS_EXPORT CPluginFactory { public: CPluginFactory (void); ~ CPluginFactory (void); // 函数名称 : Instance // 描述 : 返回全局唯一插件管理对象实例 // 返回类型 : CPluginFactory* static CPluginFactory * Instance(); } CPluginFactory* CPluginFactory::Instance() { static CPluginFactory PluginFactory; return &PluginFactory; }
今天早上同事向我展示这样一句代码:
CPluginFactory *pFactory = new CPluginFactory();
然后问我,万一外部这样使用这个类呢?
开始我轻描淡写地回答:如果这样他们用错了,他们应该使用Instance这个接口获取全局对象指针,那是他们的责任。后来我重新考虑了一下同事提的问题,想到了一个更好的设计来防范这种外部误用的情况,就是将CPluginFactory的构造函数设置为私有函数。
由此我想到用户确实会存在错误使用的情况,但这里面需要思考有没有设计者方面的责任。