Double-checked Locking,严格意义上来讲不属于无锁范畴,无论什么时候当临界区中的代码仅仅需要加锁一次,同时当其获取锁的时候必须是线程安全的,此时就可以利用 Double-checked Locking 模式来减少锁竞争和加锁载荷。目前Double-checkedLocking已经广泛应用于单例 (Singleton)模式中。

Double-checked Locking有以下特点:

Double-checked Locking模式是Singleton的多线程版本。
Double-checked Locking模式依旧会使用锁——临界区锁定,不要以为可以避免使用锁。
Double-checked Locking解决的问题是:当多个线程存在访问临界区企图时,保证了临界区只需要访问一次。

以Singleton为例,为了防止多次分配,通常Singleton的实现方式是:

//
实现1

Class singleton
{
singleton* get_instance()
{
lock();
if (instance == 0)
{
instance = new singleton;
}
unlock();
return instance;
}
}

这里存在的问题是:无论是否已经初始化都要加锁,增加了负荷,已经没有所谓的并发性能了。

要增加并发性能,可以先判断是否已经分配,在没分配的情况下才加锁,也许你想要改成下面这个样子:

// 实现2

Class singleton
{
singleton* get_instance()
{
if (instance == 0)
{
lock();
instance = new singleton;
unlock();
}
return instance;
}
}

这里存在的问题是:不能保证临界区只初始化一次,没能实现singleton的基本功能。

//
实现3 - Double-checkedLocking

Class singleton
{
singleton* get_instance()
{
if (instance == 0)
{
lock();
if (instance == 0 )
{
instance = new singleton;
}
unlock();
}
return instance;
}
}

严格的说,Double-checked locking不属于无锁编程的范畴,但由原来的每次加锁访问到大多数情况下无须加锁,就是一个巨大的进步。

版权声明:本文为博主原创文章,未经博主允许不得转载。

最新文章

  1. 在你的ASP.NET MVC中使用查找功能
  2. js传入参数为字符串问题
  3. java Io缓冲区复制文件
  4. ElasticSearch(站内搜索)
  5. 51单片机tea5767收音机 红外遥控 自动搜台 存台 DIY
  6. Android Studio开发入门-引用jar及so文件
  7. ci为什么必须得写构造函数
  8. ZTE AD3812 3G模块在linux 2.6.34 内核的开发板上的支持方法
  9. Majority Element II——LeetCode
  10. 【动态规划】XMU 1029 矩阵链乘法
  11. Javascipt 时间格式化(日期)
  12. QLinkedList和std::forward_list
  13. NEU OJ 1644 Median I
  14. Python之mysql数据库更新表数据接口实现
  15. warning C4828问题的处理
  16. java_Arrays.sort()方法
  17. SSO的定义、原理、组件及应用
  18. Structs复习 开始 第一个helloworld项目
  19. 20155227《网络对抗》Exp5 MSF基础应用
  20. 使用 spring.profiles.active 及 @profile 注解 动态化配置内部及外部配置

热门文章

  1. NYOJ-289 苹果 TLE 分类: NYOJ 2013-12-29 17:52 282人阅读 评论(0) 收藏
  2. xcodebuild和xcrun实现自动打包iOS应用程序
  3. 【bzoj1013】[JSOI2008]球形空间产生器sphere
  4. share干什么的
  5. thinkPHP生成静态分页列表
  6. HDU4871 Shortest-path tree(树分治)
  7. HDU 1163 Eddy's digital Roots(模)
  8. Difference Between Initialization and Assignment in C++
  9. hdu 3092 Least common multiple
  10. copy