实例构造函数设置一个静态成员,它是否是线程安全的?

Ant*_*ean 5 .net c# multithreading thread-safety

我正在重新考虑一些代码,并且想知道lock在实例构造函数中使用a .

public class MyClass {

    private static Int32 counter = 0;
    private Int32 myCount;

    public MyClass() {

        lock(this) {
            counter++;
            myCount = counter;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

请确认

  1. 实例构造函数是线程安全的.
  2. lock语句阻止访问该代码块,而不是静态"计数器"成员.

如果原始程序员的意图是让每个实例知道它的'count',我将如何同步访问'counter'成员以确保另一个线程不是新的a MyClass并在此设置之前更改计数计数?

仅供参考 - 此课程不是单身.实例必须只知道它们的编号.

Mik*_*all 12

如果你只是增加一个数字,那么就有一个特殊的类(Interlocked)就是这样...

http://msdn.microsoft.com/en-us/library/system.threading.interlocked.increment.aspx

Interlocked.Increment方法

增加指定的变量并将结果存储为原子操作.

System.Threading.Interlocked.Increment(myField);
Run Code Online (Sandbox Code Playgroud)

有关线程最佳实践的更多信息......

http://msdn.microsoft.com/en-us/library/1c9txz50.aspx


Rob*_*per 3

@ajmasstrean

我并不是说你应该使用单例模式本身,而是采用它封装实例化过程的方法。

IE

  • 将构造函数设为私有。
  • 创建返回类型的静态实例方法。
  • 在静态实例方法中,在实例化之前使用lock关键字。
  • 实例化该类型的一个新实例。
  • 增加计数。
  • 解锁并返回新实例。

编辑

我遇到的一个问题是,你怎么知道计数何时减少?;)

再次编辑

考虑一下,您可以向析构函数添加代码,调用另一个静态方法来递减计数器:D