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。。。感觉讲的不是很好,不往下继续看了。
posted @ 2013-02-21 22:15  sqtds  阅读(613)  评论(0编辑  收藏  举报