java多线程之内存可见性_第1页
java多线程之内存可见性_第2页
java多线程之内存可见性_第3页
java多线程之内存可见性_第4页
java多线程之内存可见性_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Java多线程之内存可见性1. 可见性介绍Java内存模型描述了Java程序中各种变量(线程共享变量)的访问规则,以及在JVM中将变量存储到内存和从内存中读取出变量这样的底层细节。1.1两条规定1.2共享变量可见性实现的原理2. synchronized实现可见性2.1 synchronized实现可见性2.2 重排序经过重排序后,代码可能会变成如下所示的情况。2.3 as-if-serial注意:有数据依赖关系的行是禁止进行重排序的,如上的sum=num1+num2,这是禁止进行重排序的。虽然如此,但是在多线程中代码重排序之后会出现很多问题,及变量的先后顺序执行会影响执行结果。3. 举例分析

2、对于这一段代码而言,若不加任何修饰,现在有两个线程来访问,一个是读线程,执行read()代码;一个是写线程,执行write()代码。 .若执行顺序如上述所言,写线程执行1.1后,假如将自己工作内存中的数据同步到主内存中,读线程执行2.1后,会读取主内存中的修改后的ready数据,然后执行2.2和2.3后,会打印result=3 .若执行顺序如上所述,result会打印result=0 .当然2.1和2.2也可以进行重排序的,因为没有数据依赖关系,只不过重排序之后如下所示。为什么会出现上述的几种顺序呢?因为编译器会对代码进行重排序,所以会出现多种情况,但是有依赖关系的行不会进行重排序。3.1 可见性分析3.2 synchronized解决方案安全代码:加一个synchronized即可。关于第3点,可以看第二章节讲解。4. volatile实现可见性4.1volatile能够保证可见性1, 这里的可见性是指在主内存中可见。2, 比如num+这类符合操作。1, java中一共有8条类似的指令,这里只是其中的两条。4.2 举例分析可见同目录下面的Example下面的vola

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论