单例的多线程使用


前一篇文章介绍了什么是单例模式以及如何使用单例模式。那么在多线程程序中我们如何使用单例模式呢?也就是说在多线程中我们如何保证类实例的唯一性?

众所周知,多线程中使用较多的是锁lock。

lock是确保一个线程位于代码的临界区时,另一个线程不进入临界区。如果其他的线程试图进入锁定的代码,将一直等待(被阻止)直到该对象被释放。

程序运行时创建一个静态只读的线程辅助对象:

public static readonly object syncroot=new object();

在同一时刻加锁的那部分代码只能被一个线程访问:

lock(syncroot)

{

if(instance==null)

{

  instance=new singleton();

}

}

上面的代码每次进行调用时都需要加锁lock,对性能有一定影响。可以先判断实例是否存在,不存在再加锁lock。

if(instance==null)

{

lock(syncroot)

{

if(instance==null)

{

  instance=new objec();

}

}

}

上面的代码中,对实例是否为空我们进行了两次判断,为什么呢?

当实例instance==null时,两个线程同时调用上面的代码,第一重条件都符合可以进入。此时由于lock机制,只能一个线程进入,另一个线程等候。这里如果没有第二重是否为null条件判断,第一个线程执行实例化对象退出后,第二个线程进入会再一次实例化对象。这样就没有达到我们单实例的目的。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM