java并发之锁

有两种锁,悲观锁,乐观锁

java和数据库都一样拥有这两种锁,数据库悲观锁for update,乐观锁每个表都有一个version字段,查询字段,然后set这个字段+1,如果操作成功而且version=version+1.update xx set version=version+1 and xx where version =1;如果有人改变version的值,那么这个操作会失败!

 java悲观锁synchronized,在jdk1.5以前性能会比乐观锁差些,但是1.5以后跟乐观锁有得一比。


java 乐观锁 跟cas有关

cas有几个概念 旧值,预期值,新值。如果预期值==新值,就把预期值赋给新值。为啥要这么麻烦呢?如果说你的预期值是3,然而别人修改成4了,那么你这个3还有用吗?没有的!所以你修改无效,重新来


cas具体使用类和atomic这个包有很大联系

package com.example.demo.Atomic;

import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicIntegerArray;

public class First {
    public static void main(String[] args) {
        /*AtomicInteger atomicInteger=new AtomicInteger(1);
        System.out.println(atomicInteger.get());
        System.out.println(atomicInteger.getAndIncrement());
        System.out.println(atomicInteger.get());
        System.out.println(atomicInteger.getAndIncrement());
        System.out.println(atomicInteger.get());*/

        int[] a=new int[]{1,2,3,4};
        AtomicIntegerArray atomicIntegerArray=new AtomicIntegerArray(a);
        atomicIntegerArray.getAndSet(1,3);
        System.out.println(atomicIntegerArray.get(0));
        System.out.println(atomicIntegerArray.get(1));
        System.out.println(atomicIntegerArray.getAndIncrement(0));//i++
        System.out.println(atomicIntegerArray.get(0));
        System.out.println(atomicIntegerArray.get(1));
    }
}


一般什么时候用乐观锁还有悲观锁呢?

当竞争不是很激烈时,使用乐观锁。当竞争很激烈时,使用悲观锁。

因为悲观锁有几个缺陷,就是

扫描二维码关注公众号,回复: 1944542 查看本文章

1.等级优先的,他也不会让它先获得锁

2.当一个获得锁之后其他都要一直等到它释放锁


乐观锁也有缺陷:产生自旋,就是当它更新不成功的时候会反复重试,无限循环,所以适合竞争低的情况

猜你喜欢

转载自blog.csdn.net/weixin_38336658/article/details/80952107