免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: zylthinking
打印 上一主题 下一主题

为什么用户空间程序不用考虑内存屏障? [复制链接]

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
91 [报告]
发表于 2011-10-20 09:16 |只看该作者
回复 88# 塑料袋

非常期待大牛的文档。。。希望能帮大家澄清这一堆的疑惑!感激不尽

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
92 [报告]
发表于 2011-10-20 09:19 |只看该作者
本帖最后由 asuka2001 于 2011-10-20 09:22 编辑

回复 90# cjaizss

那么我想问,volatile能干涉到CPU的行为吗?如果不能,那你怎么可以认为volatile可以确保LZ的程序行为正确?我只希望搞清楚这点!

另外这个疑问你也没有回答:为什么锁中需要使用内存屏障,而不是单纯的使用volatile?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
93 [报告]
发表于 2011-10-20 09:56 |只看该作者
另外一个人的帖子我不准备回了.对于你的认为,我希望你分清楚软件行为和硬件行为.编译器不是去干涉 ...
cjaizss 发表于 2011-10-20 08:40


他妈的你还显摆牛逼了, 敢不敢打赌, 各说各的技术上的道理, 我输了ID自杀, 你输了自己辞去C版版主。

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
94 [报告]
发表于 2011-10-20 10:14 |只看该作者
他妈的你还显摆牛逼了, 敢不敢打赌, 各说各的技术上的道理, 我输了ID自杀, 你输了自己辞去C版版主。 ...
zylthinking 发表于 2011-10-20 09:56



    开始骂人了,晕,你还没资格跟我争.现在心态也越来越平和了,换成之前我就要开骂了.
   再者我几时当过C版斑竹了?就算我输了也没得辞啊

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
95 [报告]
发表于 2011-10-20 10:19 |只看该作者
本帖最后由 zylthinking 于 2011-10-20 10:22 编辑

少绕圈子, 是版主, 不管什么版, 你去辞职, 不是版主那你也输了ID自杀, 别拿心态素质之类当借口, 敢不敢吧

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
96 [报告]
发表于 2011-10-20 10:27 |只看该作者
技术讨论,不用弄到这种赌斗的地步吧。。。我们是为了澄清自己的误解,提高自己的技术水平才来做技术讨论的!

论坛徽章:
0
97 [报告]
发表于 2012-12-04 20:12 |只看该作者
用户空间的多线程编程也需要考虑编译器优化问题,只不过采用的方法不是内存屏障,而是volatile关键字。
我觉得内核之所以采用内存屏障主要是为了在通常情况下能够提高效率,只在需要保序的情况下使用内存屏障。
而如果使用了volatile关键字在任何情况下都会保序,影响执行效率,不过却简化了软件设计。

这个问题我也困扰了很久,今天终于想明白了。

论坛徽章:
0
98 [报告]
发表于 2012-12-04 20:16 |只看该作者
用户空间采用volatile关键字来阻止编译器优化,这样使用简单。
内核空间采用内存屏障保序,这样效率较高。

论坛徽章:
4
天秤座
日期:2013-10-18 13:58:33金牛座
日期:2013-11-28 16:17:01辰龙
日期:2014-01-14 09:54:32戌狗
日期:2014-01-24 09:23:27
99 [报告]
发表于 2012-12-04 21:59 |只看该作者
楼上,你真心没有想明白,或者说你想明白的是一个假象。

论坛徽章:
0
100 [报告]
发表于 2013-04-12 17:58 |只看该作者
本帖最后由 beyondilove 于 2013-04-12 18:11 编辑

回复 1# zylthinking


    不是不考虑 你这个代码写的是有问题的 不管内核空间还是用户空间都要考虑
引起乱序的包括两个方面 编译器的行为指令调度(Instruction scheduling)和 CPU的乱序执行(out-of-orderexecution)
1.程序需要考虑的是编译器的指令调度 也就是内核代码里看到的用到了屏障 用户空间同样需要用
这个可以参考这篇文章http://www.goldendoc.org/2012/01/optimization-barrier/
2.至于CPU的乱序执行这个是程序不需要考虑的 至少在X86上不用考虑 Any two stores are seen in a consistent order
多发射乱序执行是为了提高流水线效率 乱序执行只是流水线的一个环节(想想教科书里面的经典的5级流水线)后续的写回store是不会乱序的 即乱序执行 顺序写回
这个看一下讲体系结构的书  Tomasulo算法相关的东西

所以你的程序里如果要保证buffrt 在 enable之前赋值 必须用屏障
而在汇编级别用屏障保证了buffrt 在 enable之前赋值 CPU会保证buffrt的写值一定在enable的写值之前
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP