java笔记--Java内存模型与线程

来源:互联网 发布:淘宝关键词重复 编辑:程序博客网 时间:2024/06/05 21:49

1、Java内存模型

        Java内存模型规定了所有的变量都存储在主内存中。每个线程还有自己的工作内存,线程的工作内存中保存了被该线程使用到的变量的主内存的副本,线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量。不同的线程之间也无法访问对方工作内存中的变量,线程间变量值得传递均需要通过主内存来完成。

2、内存间的交互操作

        主内存和工作而内存之间具体的交互协议,Java内存模型中定义了8种操作来完成。Java虚拟机保证这8种操作都是原子的、不可再分的。

        lock    ,   unlock  ,    read     ,  load    ,use   ,   assign   ,  store  ,  write  .

        不允许一个线程丢弃他的最近的assign操作。即变量在工作内存中改变了之后必须把该变化同步到主内存中。

        如果对一个变量执行lock操作,那么将会清空工作内存中此变量的值,执行引擎使用这个变量前,需要重新执行load和assign操作。

        对一个变量执行unlock之前必须先把次变量同步回主内存中。

3、对于volatile型变量的特殊规则

        当一个变量定义为volatile之后,他将具备两种特性。1,保证此变量对所有线程都是可见的。这里的可见是指当一个线程修改了这个变量的值,新值对于其他线程来说都是可以立即得知的。2,禁止指令重排序优化。

4、Java线程调度

        主要调度方式有两种:协同式线程调度和抢占式线程调度。

        协同式线程调度:线程的执行时间由线程本身来控制,线程把自己的工作执行完了之后要主动通知系统切换到另一个线程上。

        抢占式线程调度:线程的执行时间由系统决定。

5、线程的5种状态

        新建new、运行runnable、无限期等待waiting、限期等待timed waiting、阻塞blocked、结束terminated。


0 0
原创粉丝点击