测试一个条件然后锁定然后重新测试条件是否合适

发布于 2024-10-18 06:04:41 字数 592 浏览 8 评论 0原文

可能的重复:
.net 中的双重检查锁定

编辑: 很多编辑以澄清这个问题与单例无关

我发现自己编写如下代码:

    if(resourceOnDiskNeedsUpdating)
    {
        lock(lockObject)
        {
            if(resourceOnDiskNeedsUpdating) // has a previous thread already done this?
                UpdateResourceOnDisk();
        }
    }
    return LoadResourceFromDisk();

UpdateResource() 是一个缓慢的操作。 这种模式有意义吗?
有更好的选择吗?

Possible Duplicate:
Double-checked locking in .net

EDIT: lots of edits to clarify this question is not about singleton

I find myself writing code like this:

    if(resourceOnDiskNeedsUpdating)
    {
        lock(lockObject)
        {
            if(resourceOnDiskNeedsUpdating) // has a previous thread already done this?
                UpdateResourceOnDisk();
        }
    }
    return LoadResourceFromDisk();

UpdateResource() is a slow operation.
Does this pattern make sense?
Are there better alternatives?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

誰ツ都不明白 2024-10-25 06:04:41

这称为“双重检查锁定”。

你需要一个记忆栅栏来使其正确。

请参阅维基百科有关 .NET 中双重检查锁定的文章

This called "double-checked locking".

You need a memory fence to make it correct.

See Wikipedia's article on double checked locking in .NET

起风了 2024-10-25 06:04:41

我使用的另一种选择是仅使用“易失性”关键字。
http://msdn.microsoft.com/en -us/library/x13ttww7%28v=vs.71%29.aspx

An alternative I use would be to just use the 'volatile' keyword.
http://msdn.microsoft.com/en-us/library/x13ttww7%28v=vs.71%29.aspx

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文