免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 10892 | 回复: 31
打印 上一主题 下一主题

[C] 线程真的很危险? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-08-02 11:23 |只看该作者 |正序浏览
本帖最后由 zhendehaoren 于 2014-08-02 11:29 编辑

在看一本书中写道:
x=0;
thread1     thread2
lock;        lock;
x++;       x++;
unlock;    unlock;

虽然有锁的保护,但是如果编译器为了提高x的访问速度,会把x放到某个寄存器里,不同线程的寄存器各自独立,
还有种情况就是cpu乱序执行指令。即使加锁也不能保证线程安全。

但为何多线程大量被使用?


书上说解决方法有两个 volatile 和 barrier  但是说实话很少见用到过。

论坛徽章:
6
2015年辞旧岁徽章
日期:2015-03-05 16:13:092015年迎新春徽章
日期:2015-03-05 16:13:092015小元宵徽章
日期:2015-03-06 15:58:1815-16赛季CBA联赛之浙江
日期:2016-11-05 14:38:4115-16赛季CBA联赛之新疆
日期:2016-11-11 18:38:06
32 [报告]
发表于 2014-10-12 17:31 |只看该作者
本帖最后由 爻易 于 2014-10-12 17:34 编辑

看这段代码应该是作者特意构建出来以说明问题的,这无可厚非。

只是变量并未严格置于锁的保护之下,在获得锁之前,程序就已经开始访问变量了。

因为这个原因,所以必须另外加上关键字保护。但如果所有读写变量的操作都放在获得锁之后的话,就无须关键字保护。

论坛徽章:
0
31 [报告]
发表于 2014-10-12 14:15 |只看该作者
volatile 不能少

论坛徽章:
0
30 [报告]
发表于 2014-08-04 10:56 |只看该作者
不理解的可以参考一片论文大意是:为什么线程不能由库实现

论坛徽章:
12
巳蛇
日期:2013-09-16 15:32:242015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之约旦
日期:2015-02-11 14:38:37双鱼座
日期:2015-01-05 11:05:47戌狗
日期:2014-12-08 09:41:18戌狗
日期:2014-08-15 09:29:29双子座
日期:2014-08-05 09:17:17卯兔
日期:2014-06-08 15:32:18巳蛇
日期:2014-01-27 08:47:08白羊座
日期:2013-11-28 21:04:15巨蟹座
日期:2013-11-13 21:58:012015年亚洲杯之科威特
日期:2015-04-17 16:51:51
29 [报告]
发表于 2014-08-04 10:16 |只看该作者
写编译器/库的人不是傻子,该考虑的情况人家都考虑了。

锁本身就有内存屏障的语义,所以不用使用者考虑cache以及CPU乱序的问题。

编译器做优化时,不会用寄存器缓存一个全局变量并跨过一次函数调用。对于C语言/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
28 [报告]
发表于 2014-08-04 09:53 |只看该作者
folklore 发表于 2014-08-02 13:38
回复 6# hellioncu


所有的锁, 基本上归结到用 cpu 锁 + 屏障 实现它自己的语意, 因此, 除非这个锁不合格, 否则不会有问题

论坛徽章:
0
27 [报告]
发表于 2014-08-04 05:25 |只看该作者
这个问题我看了很震惊,像TLPI这些书上根本没提到这样的情况。
看来不少人对这个问题都不陌生,大家看的都是些什么书啊?

论坛徽章:
0
26 [报告]
发表于 2014-08-03 22:08 |只看该作者
回复 21# zhendehaoren


    书上写的是错的,不用担心这个问题,除非你用的编译器太老。

论坛徽章:
4
白羊座
日期:2013-09-17 21:59:30技术图书徽章
日期:2013-10-12 22:16:03白羊座
日期:2013-10-14 11:01:40双子座
日期:2013-12-17 18:26:39
25 [报告]
发表于 2014-08-03 15:57 |只看该作者
对于遵循posix标准的线程没有问题,别的不知道。
posix规定pthread_mutex_lock和pthread_mutex_unlock必须做内存同步,除了以下的情况:
  1. The pthread_mutex_lock() function need not synchronize memory if the mutex type if PTHREAD_MUTEX_RECURSIVE and the calling thread already owns the mutex. The pthread_mutex_unlock() function need not synchronize memory if the mutex type is PTHREAD_MUTEX_RECURSIVE and the mutex has a lock count greater than one.
复制代码

论坛徽章:
0
24 [报告]
发表于 2014-08-03 13:21 |只看该作者
三爷,。。。  我不说了
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP