java内存模型

TPS:每秒事务处理器;

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

主内存与工作内存:java内存模型主要是定义程序中各个变量的访问规则,即在虚拟机中将变量存储到内存和从内存中取出变量这样的底层细节。
java内存模型规定了所有的变量都存储在主内存中。每条线程还有自己的工作内存。线程,主内存,工作内存的关系为:java线程->工作内存->主内存。
这里所讲的工作内存等与虚拟机运行内存并不是一个层次的内存划分,如果一定到对应,主内存主要对应java堆中的对象实例数据部分。工作内存对应虚拟机栈中的部分区域。从更低层次上说,主内存就直接对应物理硬件的内存,为了获取更好的运行速度,虚拟机可能会让工作内存优先存储与寄存器和告诉缓存中,

内存间交互操作:lock ,unlock,read,load,use,assign,store,write.

volatile:是java虚拟机提供的最轻量级的同步机制。
特性:
1、保证此变量对所有线程的可见性。
保证volatile修饰的值原子性,对任意单个volatile变量的读/写具有原子性,单类似于volatile++这种复合操作不具有原子性。

2、禁止指令重排序。
啥是指令重排?指令重排序是指CPU采用了允许将多条指令不按照程序规定的顺序分开发送给各相应电路单元处理。但并不是任意指令重排,cpu需要正确处理指令保证各单元获取正确的结果。
用volatile修饰的变量,会有一个内存屏障,也就是锁,用于同步。

对于long类型和double型变量的特殊规则

原子性,可见性和有序性
java内存模型来直接保证原子性,可见性以及有序性,基本上是包括volatile和sychronized锁。

Java与线程

线程的实现:使用内核线程实现,使用用户线程实现和使用用户线程加轻量级进程混合实现。

线程状态:新建,运行,无限期等待,限期等待,阻塞,结束。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

shichangle01

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值