1 悲观锁和乐观锁
悲观锁:在sql语句末尾加上 for update
乐观锁:在sql的where语句中添加version条件
update tablel set name=#{name),age=#{age),version=${version)+1 where id =#{id} and version=#{version}
乐观锁并不会使用数据库提供的锁机制, 一般在表中添加version 宇段或者使用业务
状态来实现。乐观锁直到提交时才锁定,所以不会产生任何死锁。
2 公平锁和非公平锁
公平锁 :antLock pairLock = new ReentrantLock(true);
非公平锁: ReentrantLock pairLock = new ReentrantLock(false);
在没有公平性需求的前提下尽量使用非公平锁,因为公平锁会带来性能开销。
3 独占锁和共享锁
独占锁:保证任何时候都只有一个线程能得到锁,ReentrantLock、synchronized都属于独占锁;
共享锁:允许多个线程同时进行读操作,如ReadWriteLock允许多个线程同时读操作。
4 自旋锁
当前线程在获取锁时,如果发现锁已经被其他线程占有,它不马上阻塞自己,在不放弃CPU 使用权的情况下,多次尝试获取, 默认次数是10 ,可以使用-XX :PreBlockSpinsh 参数设置该值),这种实现方式可能会浪费CPU的时间。