好吧,我在自己的项目中使用单例。最常用的单例实现可能是Meyer的单例,也可能是使用std :: call_once或pthread_once的单例。两者对于并行计算都是线程安全的
please ping localhost
Meyer使用局部静态变量来确保线程安全并返回实例标识,而后者则通过call_once实现并获取指针。在我的实验中,Meyer的隐含性更快一些。但是,大多数项目都使用call_once方法来实现最基本的单例实现,尽管使用Meyer实现的项目中的一小部分也是如此。我只是想知道有没有遵循的原则,这两种不同的实现有什么利弊?
答案 0 :(得分:4)
call_once
版本保留指向实例的指针,并使用new
创建实例。由于从未在指针上调用delete
,因此如果需要在实例析构函数中运行明智的代码,则此解决方案会带来一些麻烦。除了在实例出口处烦人的悬空指针之外,如果实例析构函数只是您示例中的默认实例析构函数,则可以考虑使用它。