jvm脉络梳理4-JMM协议

17.JMM:Java Memory Model
17.1 什么是JMM:
  • 百度百科:规定了java虚拟机与计算机内存之间如何协同工作,一个线程何时可以看到由其他线程修改的变量,以及如何同步访问的共享变量。本质是定义了线程与主内存之间的抽象关系。线程—>工作内存—>主内存
17.2 作用:官方,博客,视频
  • 缓存一致性协议,用于定义数据读写的规则(遵守找到此规则)
  • JMM定义了线程工作内存和主内存之间的抽象关系:线程之间的共享变量存储在主内存(main)中,每个线程有自己的一个私有的本地内存(ThreadLocalMemory)
    在这里插入图片描述
  • 解决共享对象可见性问题:voliate这个关键字会将现场中的变量在改动和立即fulsh到主内存中。
  • 所有的变量都存储在主内存中
  • 线程的工作内存保存了该线程的使用的变量和主内存的副本copy
  • 线程对变量的操作只能在工作内存中处理,不能直接读写主内存
  • jmm定义了三个特性 原子性,有序性,可见性。
17.3 如何:JMM是抽象概念、理论
  • jmm的内存交互操作有哪些?是怎么操作的?流程是什么样的?
  • 内存交互操作一共有8中,lock,read,load,use,assign,restore,write,unlock
线程读写数据的流程

1.读数据   lock加锁 从主内存中read数据,然后把数据load到工作内内存中,线程use 数据

2.写数据  使用完成后,线程assign数据到工作内存,把数据从工作内存中store到主内存,并把数据write到主内存中,unlock 释放锁
17.4 volatile关键字有什么作用?底层是怎么实现的?
  • volatile关键字作用有两点:
1.保证可见性,当前线程修改变量,别的线程也可以看到。它会修改当前前工作内存中的值,然后同步主存中,同时使其他线程中的变量值失效。

2.保证有序性 底层通过加内存屏障的方式,保证有序性。读操作加loadload, loadstore两个内存屏障。写操作加storestore,storeload两个内存屏障。
17.5volatile可以保证原子性吗?如果不能怎么解决
  • volatile 不能保证原子性,可以使用synchronized关键字解决。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值