synchronized
摘要:基本使用 Synchronized是Java中解决并发问题的一种最常用的方法,也是最简单的一种方法。Synchronized的作用主要有三个: 原子性:确保线程互斥的访问同步代码; 可见性:保证共享变量的修改能够及时可见,其实是通过Java内存模型中的 “对一个变量unlock操作之前,必须要同步到
阅读全文
posted @
2023-03-29 22:56
zhengbiyu
阅读(50)
推荐(0) 编辑
volatile
摘要:volatile是 Java 中的一个关键字,当一个变量是共享变量,同时被 volatile 修饰当值被更改的时候,其他线程再读取该变量的时候可以保证能获取到修改后的值,通过 JMM 屏蔽掉各种硬件和操作系统的内存访问差异 以及 CPU 多级缓存等导致的数据不一致问题。 需要注意的是,volatil
阅读全文
posted @
2023-03-29 21:58
zhengbiyu
阅读(53)
推荐(0) 编辑
Happens-Before原则
摘要:Happens-Before 程序顺序原则:如果程序操作 A 在操作 B 之前,那么多线程中的操作依然是 A 在 B 之前执行。 监视器锁原则:在监视器锁上的解锁操作必须在同一个监视器上的加锁操作之前执行。 volatile 变量原则:对 volatile 修饰的变量写入操作必须在该变量的读操作之前
阅读全文
posted @
2023-03-29 21:52
zhengbiyu
阅读(18)
推荐(0) 编辑
内存模型
摘要:JMM(Java Memory Model,Java 内存模型) JMM 是一个抽象概念,由于 CPU 多核多级缓存、为了优化代码会发生指令重排的原因,JMM 为了屏蔽细节,定义了一套规范,保证最终的并发安全。它抽象出了工作内存与主内存的概念,并且通过八个原子操作以及内存屏障保证了原子性、内存可见性
阅读全文
posted @
2023-03-29 21:50
zhengbiyu
阅读(74)
推荐(0) 编辑
八种原子操作
摘要:为了支持 JMM,Java 定义了 8 种原子操作(Action),用来控制主存与工作内存之间的交互: read 读取:作用于主内存,将共享变量从主内存传动到线程的工作内存中,供后面的 load 动作使用。 load 载入:作用于工作内存,把 read 读取的值放到工作内存中的副本变量中。 stor
阅读全文
posted @
2023-03-29 20:03
zhengbiyu
阅读(286)
推荐(0) 编辑