CAS算法:
保证数据操作的原子性
内存值 V
预估值 E
更新值 N
当V==E的时候 将N的值赋给V;
如果V != E的时候 说明其他线程已经将预期值进行更改,N值想不会赋值给V。
不管赋值是否成功。CAS算法会返回当前的V值。
JAVA锁:
一、重入锁(ReentrantLock)与内部锁(Synchorized):
重入锁与内部锁的功能上接近,内部锁能完成的事情,重入锁都可以实现。
不同在于1.重入锁需要在finally中关闭锁,而内部所不需要关闭,会自动关闭。
2.重入锁会通过condition机制对锁进行控制,而内部锁需要通过wait()、notify()方法实现对锁的控制。
二、自旋锁:
因为线程的挂起,恢复非常消耗系统性能以及频繁的上下文切换会导致资源的浪费。JVM中如果当前线程没有资源,线程不会被立即挂起,JVM会将线程放入一个空循环中(自旋),如果线程获取到了锁,就执行线程,如果长时间没有获得锁,线程才会被挂起。
三、偏向锁、轻量级锁、重量级锁:
当对象在JVM启动的四秒以内被创建,对象会处于无锁状态,(JVM四秒启动以后、对象会变成偏向锁状态),当无锁状态下的对象被synchronized关键字修饰时,锁膨胀成偏向锁,当其他对象同样想要争夺锁的时候,锁膨胀为轻量级锁,没获取到锁的线程会进行自旋,当自旋十次以上,锁变成重量级锁。
四、读写锁:
读写分离,减少锁的竞争,提高性能。readLock操作、writelock操作。
java常见锁
最新推荐文章于 2024-05-18 18:41:47 发布