学习内容:
提示:这里可以添加要学的内容
例如:
1、 悲观锁和乐观锁
2、 原子类
3、 ThreadLocal
4、 了解什么是ABA问题
悲观锁和乐观锁
悲观锁
比喻:是一个一朝被蛇咬,十年怕井绳一样,认为谁都要抢我的东西,所以需要挨个问一下你是干嘛的。
就是认为线程的安全问题时常发生,所以会进行上锁,但是上锁有一个问题就是浪费比较多的资源和见底程序的性能,因为里面会有上锁和锁释放的过程
乐观锁
比喻:不会防着所有人,认为周围都是好人
虽然不会防着但是自己也会留个心眼,有两个方案:
- 版本号机制
利用版本号记录数据更新的次数,一旦更新版本号加1,线程修改数据后会判断版本号是否是自己更新的次数,如果不是就不更新数据。 - CAS (Compare And Swap)比较和交换算法
- 通过内存的偏移量获得数据的值
- 计算出一个预计的值
- 将提交的实际值和预计值进行比较,如果相同执行修改,如果不同就不修改
悲观锁和乐观锁对比
- 悲观锁更加重量级,占用资源更多,应用线程竞争比较频繁的情况,多写少读的场景
- 乐观锁更加轻量级,性能更高,应用于线程竞争比较少的情况,多读少写的场景
原子类
AtomicInteger类
原子整数,底层使用了CAS算法实现整数递增和递减操作
常用方法:
- incrementAndGet 原子递增
- decrementAndGet 原子递减
public class AtomicDemo {
static int count = 0;
static AtomicInteger integer = new