各位大神好:
主线程与分线程共享一个成员变量count(不用volatile修饰的),那么在分线程中循环执行一百次count++
,什么时间分线的count值与主线程同步呀!
也就说分线程执行read and load 从主存复制count变量到自己的工作内存中,然后use and assign 是执行一百次count++之后才执行store and write 把工作内存数据刷新主存,还是中中间每一次count++都会呀
Java线程工作内存与主内存的问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- u010536370 2016-12-06 03:33关注
个人感觉绝对不是执行完一百次count++才执行store and write,根据java 内存模型规则:
1、不允许read和load、store和write操作之一单独出现,以上两个操作必须按顺序执行,但没有保证必须连续执行,也就是说,read与load之间、store与write之间是可插入其他指令的。
2、不允许一个线程丢弃它的最近的assign操作,即变量在工作内存中改变了之后必须把该变化同步回主内存。
可以推断出count++,就是一次assign,根据第二条规则,不允许丢弃最近的assign,所以必定有一次store and write,又根据第一条read and load 和store and write 不能单一出现,所以有一次store and write 必定有一次 read and load,因此推断出,每一次count++都会执行 read 、 load 、use 、assign、store、write
欢迎加入我的QQ讨论群:180075424解决 无用评论 打赏 举报
悬赏问题
- ¥35 平滑拟合曲线该如何生成
- ¥100 c语言,请帮蒟蒻写一个题的范例作参考
- ¥15 名为“Product”的列已属于此 DataTable
- ¥15 安卓adb backup备份应用数据失败
- ¥15 eclipse运行项目时遇到的问题
- ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
- ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
- ¥15 自己瞎改改,结果现在又运行不了了
- ¥15 链式存储应该如何解决
- ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站