JVM线程资源同步机制(分布式java应用笔记)

首先我们分析下面的代码:

int i = 0;

public int getNextId(){
    return i++;
}
它的执行步骤为:
1,jvm首先在main memory(jvm堆)给i分配一个内存存储场所,并存储其值为0.
2,线程启动后,会分配一片working memory 区(通常是操作数栈),当线程执行到return i++时,jvm并不是简单的一个步骤就可以完成的。i++在jvm中分为装载i,读取i,进行i++操作,存储i及写入i的5个步骤。
装载i
   线程 发起一个装载i的请求给jvm线程执行引擎,引擎接收请求后向main memory发起一个read i的指令。
   当read i执行完毕后,一段时间线程会将i的值从main memory 区复制到working memory中。
读取i
    此步负责的是从main memory中读取i(感觉这一步应该是从working memory中读取的)
进行i+1操作
    线程完成
存储i
    将i+1的值赋给i,然后存储到working memory中。
写入i
    一端时间后i的值回写到main memory中。
 
简单的说就是会出现线程区域内存和主内存会出现i的复制读取,这时有可能出现2个内存区域的i不一致。
 
jvm保证以下操作是顺序的:
1,同一个线程上的操作
2。。。感觉讲的不是很好,不往下继续看了。

转载于:https://www.cnblogs.com/sqtds/archive/2013/02/21/2921351.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值