Java 内存模型与线程

2019-04-01  本文已影响0人  leenpong

概述:

1.每个电脑的处理器(CPU)都有自己的高速缓存以达到读写速度提高,但多个高速缓存共享同一块主内存,当多个处理器的运算任务涉及到主内存中的同一块数据,就有可能发生各自的数据不一致,针对这种情况,需要有一定的协议来解决数据一致性的问题。
2.JAVA虚拟机中通过实现自己的‘内存模型’对高速缓存和内存的读写的过程抽象。
3.为了让处理器中的运算单元被充分利用,处理器可能对输入的代码进行乱序折行优化,然后再进行重组,所以计算的的结果不能依靠代码中的顺序,在JAVA虚拟机中,对应的为 指令重排。

image.png

主内存与工作内存:

1.java内存模型是为了定义程序中各个变量的访问规则,即变量存储到主内存和从主内存中取出的操作。(该变量不包括局部变量,因为其实线程私有的,不会共享)
2.所有变量(实例,静态字段,数组等)都存储在主内存,每条线程都有赞成的工作内存(高速缓存),工作内存中保存的变量是该变量从主内存的拷贝,线程对变量的所有操作都必须在工作内存里面,不允许直接操作主内存,不同的线程无法互相访问工作内存中的变量,必须通过访问主内存的变量
ps:volitate变量依然有拷贝

JAVA虚拟机中定义了8种操作,将一个变量正确地从主内存拷贝到工作内存,或者从工作内存同步到主内存。

volatile关键字

不符合以下2中情况下volatile变量还是非线程安全的:

原子性:

JAVA中提供了synchronized关键字,在synchronized块之间的操作是具备原子性的。

可见性:

有序性:

线程相关:

实现线程有3种方式:内核线程,用户线程,用户加轻量级进程

状态:
1.new.
2.运行runnale:
3.无限期等待:这种情况不会分配cpu时间,实现方式有:Object.wait(),thread.join.
4.限期等待:这种情况不会分配cpu时间。实现方式有:
Object.wait(times), Thread.join(time),Thread.sleep(time)
5.阻塞(blocked):等待获取一个排他锁。
6.结束。

上一篇下一篇

猜你喜欢

热点阅读