Java多线程-1-JMM

一、JMM

1、概念

JMM(Java Memory Model),Java内存模型

线程间的通信和同步(并发执行的活动实体),都由JMM来控制

Java线程间的通信,JMM决定了一个线程对共享变量的写入何时对另外一个线程可见

Java线程间的同步,程序中用于控制不同线程间操作发生相对顺序的机制

JMM主要结构包括:

  1. 主内存(共享内存),用于保存共享变量(堆中保存的:对象的实例和数组、方法区中保存的:静态变量)
  2. 本地内存(工作内存),每个线程执行时,所使用的内存区域,它保存了共享变量的副本

2、内存交互操作指令

JMM定义了8个操作指令:

  1. read和load

    read读取主内存中的数据,并传输给工作内存

    load将read的变量值赋值给工作内存中的变量的副本

  2. use和assign

    use将工作内存中的变量,传递给执行引擎

    assign将执行引擎对变量进行赋值

  3. store和write

    store将工作内存中的数据,传输给主内存

    write将store传输过来的变量存储到主内存中

  4. lock和unlock

    lock将主内存中的变量标识为一个线程独占的状态

    unlock对主内存中锁定的变量进行解锁

      read          load
主内存 ----> 工作内存 ----> 共享变量的副本

        use          assign
工作内存 ----> 执行引擎 ----> 共享变量的副本

            write         store
共享变量的副本 ----> 工作内存 ----> 主内存

      lock/unlock
主内存    ---->    共享变量

3、内存可见性

【1】问题引出

private static int i = 0;

public static void main(String[] args) {
   
    new Thread(() -> {
   
        try {
   
            Thread.sleep(1000);
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }

        i++;
        System.out.println("数值被改变为:" + i)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值