免费注册 查看新帖 |

Chinaunix

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

关于多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 09:33 |只看该作者
原帖由 baicj 于 2008-8-26 09:08 发表
一般在多线程程序里读写内存数据都是使用
lock();
x=y;
unlock();
这样的模式。
就算是这样加锁了,我还是有点疑惑,在多cpu环境下,x是不是依然存在线程不同步的问题?因为每个cpu使用自己独立的缓存。在 ...

其实你的问题就是cache一致性的问题了
等zx_wing给解释一下某个实例
我看过一个文档,挺容易理解的,也可以看看

cache.pdf

380.51 KB, 下载次数: 562

论坛徽章:
0
3 [报告]
发表于 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