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

本文深入探讨Java内存模型,包括变量存储机制、线程工作内存原理、主内存与工作内存之间的交互操作、volatile变量的特殊规则及Java线程调度机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值