我们是不是真的需要锁和内存屏障
2011-03-26 23:09
232 查看
使用共享的可写字段但是不使用锁或者内存屏障通常会引起麻烦。在这个问题上有许多误导信息,包括MSDN文档,MSDN上说明了,对于MemoryBarrier仅仅在弱内存顺序的多核系统中使用,比如一个系统使用多个安腾处理器。我们可以用一段代码来演示内存屏障对于普通的Intel Core-2和奔腾处理器也是很重要的。你需要运行一段经过优化的并且没有debugger的代码。(在visual studio中选中Release模式,然后非debugging模式运行:
static void Main(string[] args)
{
bool complete = false;
var t = new Thread(() =>
{
bool toggle = false;
while (!complete)
{
toggle = !toggle;
}
});
t.Start();
Thread.Sleep(1000);
complete = true;
t.Join(); // Blocks indefinitely
Console.WriteLine("end");
}
这段代码将不会终止,因为complete变量被cpu寄存器缓存了。在while循环内插入Thread.MemoryBarrier();可以解决这个问题。
下面几项隐式的生成内存屏障。
C#的lock语句,Monitor.Enter/Monitor.Exit)
所有的在Interlocked类的方法
线程池上的异步调用,包括异步委托,APM回调,Task
信号结构
任何依靠信号结构人,比如Task上的starting和waiting
static void Main(string[] args)
{
bool complete = false;
var t = new Thread(() =>
{
bool toggle = false;
while (!complete)
{
toggle = !toggle;
}
});
t.Start();
Thread.Sleep(1000);
complete = true;
t.Join(); // Blocks indefinitely
Console.WriteLine("end");
}
这段代码将不会终止,因为complete变量被cpu寄存器缓存了。在while循环内插入Thread.MemoryBarrier();可以解决这个问题。
下面几项隐式的生成内存屏障。
C#的lock语句,Monitor.Enter/Monitor.Exit)
所有的在Interlocked类的方法
线程池上的异步调用,包括异步委托,APM回调,Task
信号结构
任何依靠信号结构人,比如Task上的starting和waiting
相关文章推荐
- cocoapods的移除与安装(有的时候我们需要降低Cocoapods的版本来解决第三方库的兼容问题.)
- 我们需要getter和setter方法么?
- 穆穆读的一些书籍推荐,读书的理由?读书的好处?为什么要读书?读什么书?让我们一起来读书,总之我们需要学习新的东西来适应这个社会的飞速变化。
- 将网站当作一盆花,需要我们精心呵护
- 杂谈SharpDx中的WIC组件——我们需要WIC的图片编码功能么?
- 自动垃圾回收学习笔记-我们为什么需要自动垃圾回收
- 我们是不是经常这样~~
- 第九题:【数据结构】【微软面试题】假设我们有一个队列 我们需要快速的找到里面存储的最大值 该怎么做?
- 为什么我们做的不是客户需要的
- 10月20日-我们是不是坐以待毙?
- 思维探索者:我们需要演绎与归纳
- SSO - 我们为何需要单点登录系统
- iOS开发之苹果应用6.1日起需兼容IPv6,那么作为开发者我们需要做些什么呢?【科普IPV6】
- 我们需要感恩
- 云时代,我们需要PostgreSQL,需要服务端编程
- 【转载】为什么我们需要域?Active Directory系列之一
- 为什么我们需要域?Active Directory系列之一
- 移动互联网来势汹汹,我们还需要PC网站吗?
- 我们是不是对高考太过敏了?
- C\C++编译器的未来.我们还需要C++么?