java内存模型与线程

1.java内存模型

        1.1   java虚拟机规范中试图定义一种java内存模型来屏蔽掉各种硬件和操作系统的内存访问差异,以实现让java程序在各种平台下都能达到一致的内存访问效果。

        1.2  java内存模型的主要目标是定义程序中各个变量的访问规则,即在虚拟机中将变量存储到内存和内存中取出变量这样的底层细节。此处的变量(Variables)与java编程中所说的变量有所区别,它包括了实例字段、静态字段和数组对象的元素,但不包括局部变量与方法参数,因为后者是线程私有,不会被共享,自然不存在竞争问题。

      线程、主内存、工作内存三者的交互关系如图所示。

      1.3 对于volatile型变量的特殊规则

              1.3.1 volatile 变量只能保证可见性,在不符合以下2条规则的运算场景中,我们仍然要通过加锁(使用synchronized或者java.util.consurrent中的原子类)来保证原子性。

  •  运算结果并不依赖变量的当前值,或者能都确保之后单一的线程修改变量的值

变量不需要与其他的状态变量共同参与不变约束。

              1.3.2 volatile变量的第二个语义是禁止指令重排序优化,普通的变量仅仅会保证在该方法的执行过程中所有依赖赋值结果都能够获取正确的结果,而不能保证变量赋值操作的顺序与程序代码中的执行顺序一致

2.原子性、可见性、有序性

  •  原子性:  由java内存模型来直接保证的原子性变量操作包括read、load、assign(把一个执行引擎接收到的值赋值给工作内存的变量)、use(把工作内存中一个变量的值传递给执行引擎,每当虚拟机遇到一个需要使用到变量的值得字节码指令时将会执行这个操作)、store、write。
  • 可见性:可见性是指一个线程修改了共享变量的值,其他线程能够立即得知这个修改,java内存模型是通过在修改后将新值同步到回内存,在变量读取前从主内存刷新变量值这种依赖主内存作为传递媒介的方式来实现可见性,volatile的特殊规则保证了新值能立即同步到主内存,以及每次使用前立即从主内存刷新。
  • 有序性:java程序中天然的有序性可以总结为一句话,如果在本线程内观察,所有的操作都是有序的,如果在另一个线程中观察另一个线程,所有的操作都是无序的。前半句是指“线程内表现为串行的语义”,后半句是指“指令重排序”现象和“工作内存与主内存同步延迟”现象。

 

 

            

        

 

 

        

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值