首先-大多数类将永远不需要是线程安全的。使用YAGNI:仅当你知道实际上将要使用它(并对其进行测试)时,才应用线程安全性。
对于方法级的东西,有
[MethodImpl]:
[MethodImpl(MethodImplOptions.Synchronized)]public void SomeMethod() {}这也可以用于访问器(属性和事件):
private int i;public int SomeProperty{ [MethodImpl(MethodImplOptions.Synchronized)] get { return i; } [MethodImpl(MethodImplOptions.Synchronized)] set { i = value; }}请注意,默认情况下,类似字段的事件是同步的,而自动实现的属性则不是:
public int SomeProperty {get;set;} // not synchronizedpublic event EventHandler SomeEvent; // synchronized就个人而言,我不喜欢使用MethodImpl锁this或typeof(Foo)-这是违反最佳做法的实现。首选选项是使用自己的锁:
private readonly object syncLock = new object();public void SomeMethod() { lock(syncLock) { }}注意,对于类似字段的事件,锁定实现取决于编译器。在较旧的
Microsoft编译器中,它是
lock(this)/ lock(Type)-但是,在较新的编译器中,它使用
Interlocked更新-因此具有线程安全性而没有令人讨厌的部分。
这允许更精细的用法,并允许使用
Monitor.Wait/ Monitor.Pulseetc在线程之间进行通信。



