请选择 进入手机版 | 继续访问电脑版

Java并发复习笔记

[复制链接]
尊悦模具刘沛昌 发表于 2021-1-1 17:46:56 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题
目次
1.并发编程三大特性——原子性、可见性、有序性
2.Java内存模子(JMM)是什么?
3.volatile作用是什么?volatile使用时的注意事项。
4.synchronized的实现原理
5.CAS是什么?使用CAS注意事项以及如何解决?
6.happens-before原则
7.JVM对锁的优化(方向锁、轻量级锁、重量级锁)

 
1.并发编程三大特性——原子性、可见性、有序性

1).原子性(Lock、synchronized可以包管原子性,volatile无法包管原子性)
原子性是指一个操纵大概多个操纵,要么全部执行而且执行的过程不会被任何因素打断,要么就都不执行。
2).可见性(volatile可包管可见性,synchronized、Lock也能包管可见性)
可见性是指当多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立刻看得到修改的值。
3).有序性(volatile可包管有序性,因为可克制重排序,synchronized、Lock也可包管有序性)
即步调执行的顺序按照代码的先后顺序执行。
 
2.Java内存模子(JMM)是什么?

所有的变量都存储在主内存中,每个线程尚有自己的工作内存,线程的工作内存中生存了被该线程使用到的变量的主内存副本拷贝,线程对变量的所有操纵(读取、赋值等)都必须在工作内存中举行,而不能直接读取主内存中的变量。不同线程之间也无法直接访问对方工作内存中的变量,线程间变量值的通报均需要通过主内存来完成。
 
3.volatile作用是什么?volatile使用时的注意事项。

volatile的两个语义:
1)包管变量对所有线程的可见性,即某个线程修改了这个变量的值后,新值对其他线程来说是立刻可见的。
2)克制指令重排序优化
 
volatile的适用情况如下(因为volatile无法包管原子性)
1)运算效果并不依赖变量的当前值,大概能够确保只有单一的线程修改变量的值。
举例:volatile int i; i++就依赖i原来的值,所以不适用
2)变量不需要与其他的状态变量共同到场稳定约束。
 
4.synchronized的实现原理

synchronized关键字颠末编译之后,会在同步块的前后形成monitorenter和monitorexit两个字节码指令。
JVM在执行monitorenter时会实验获取锁,执行monitorexit时会实验释放锁。
 
5.CAS是什么?使用CAS注意事项以及如何解决?

compareAndSwap,比力并交换。
CAS存在ABA问题。使用JDK atomic包中的AtomicStampedReference可解决ABA问题。
 
6.happens-before原则

步调次序规则:一个线程内,按照代码顺序,书写在前面的操纵先行发生于书写在背面的操纵。
锁定规则:一个unLock操纵先行发生于背面临同一个锁额lock操纵。
volatile变量规则:对一个变量的写操纵先行发生于背面临这个变量的读操纵。
通报规则:如果操纵A先行发生于操纵B,而操纵B又先行发生于操纵C,则可以得出操纵A先行发生于操纵C。
线程启动规则:Thread对象的start()方法先行发生于此线程的每个一个动作。
线程中断规则:对线程interrupt()方法的调用先行发生于被中断线程的代码检测到中断事件的发生。
线程终结规则:线程中所有的操纵都先行发生于线程的终止检测,我们可以通过Thread.join()方法竣事、Thread.isAlive()的返回值手段检测到线程已经终止执行。
对象终结规则:一个对象的初始化完成先行发生于他的finalize()方法的开始。
 
7.JVM对锁的优化(方向锁、轻量级锁、重量级锁)

方向锁:仅有一个线程获取锁时,不加锁
轻量级锁:竞争不激烈时,乐观锁,CAS
重量级锁:竞争激烈时,灰心锁

来源:https://blog.csdn.net/hanhan122655904/article/details/111958933
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

发布主题

专注素材教程免费分享
全国免费热线电话

18768367769

周一至周日9:00-23:00

反馈建议

27428564@qq.com 在线QQ咨询

扫描二维码关注我们

Powered by Discuz! X3.4© 2001-2013 Comsenz Inc.( 蜀ICP备2021001884号-1 )