jvm工作内存与主内存

工作内存中,存有方法栈帧,以及寄存器,pc,这可以理解,但是为啥要讲引用的一些主内存变量也要复制到工作内存?我觉得完全没必要啊,这反而导致了缓存一致性问题啊。还是说读写主内存有什么我不知道的大代价?(工作内存与主内村不是都在物理内存里吗,访问速度按理说没有太大区别啊,难道是因为lock的代价?或者说对总线的竞争?)

求各路大神解%%%

阅读 3.7k
1 个回答

会由主内存复制到工作内存的变量主要有两种。一种是显式定义了局部变量的,例如在方法内部XXX foo = this.bar;;另一种则是在多核或多CPU系统中,主内存中的数据被读入到了不同的高速缓存中。

前者实际上只对引用类型有影响,而后者则会影响所有被读入变量的一致性。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题