免费注册 查看新帖 |

Chinaunix

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

关于多cpu下的数据同步问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-26 09:08 |显示全部楼层 |倒序浏览
一般在多线程程序里读写内存数据都是使用
lock();
x=y;
unlock();
这样的模式。
就算是这样加锁了,我还是有点疑惑,在多cpu环境下,x是不是依然存在线程不同步的问题?因为每个cpu使用自己独立的缓存。在cpu A上数据发生变化,在cpu B的缓存里是不是一定能得到更新?
x=y这一条简单语句在linux内核里会做哪些工作?会去处理内存页dirty位之类的东西么?

论坛徽章:
0
2 [报告]
发表于 2008-08-26 10:53 |显示全部楼层
这个文档不错。原来cache一致性是在硬件上解决的。
对于内存块的读写,加锁就可以解决问题了。
那么像小数据,比如int型数据的内存读写还需要加锁么?因为在cache上已经是一致的了,而且也不存在数据不完整的问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP