首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >泄密的梅耶斯·辛格尔顿:这是线安全吗?

泄密的梅耶斯·辛格尔顿:这是线安全吗?
EN

Stack Overflow用户
提问于 2022-01-09 17:37:06
回答 1查看 182关注 0票数 2

我实现了一个Meyers Singleton,然后意识到它可能容易受到破坏性失败问题的影响。

因此,我将代码更改为:

代码语言:javascript
复制
Instance *getInstance()
{
    static Instance* singleton = new Instance();
    return singleton;
}

在实现这个程序之后,并且没有出现明显的错误,一个同事实现了一个不同的单例,转而使用了std::call_once

现在我已经意识到,经过大量的搜索,我无法找到"Leaky“是否是一个线程安全模式。是否应该将泄漏的单例更改为std::call_once?还是因为-是安全的关系?

指针是否被认为是“块范围”变量?如果是这样的话,我认为它将是线程安全的,但如果不是的话,在当前的漏单例方法中引入了大量的bug。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-10 03:13:34

是的,这是线程安全的:没有两个线程将尝试在同一时间使用静态存储时间初始化相同的变量。这包括计算初始化器的全部内容。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70643880

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档