锁作用
java中的锁是用来控制多个线程访问共享资源的方式。一般来说一个锁能够防止多个线程同时访问共享资源(读写锁,读锁是共享锁允许多个线程读共享资源)。
锁的分类
- 乐观锁:在访问资源时,认为竞争不总是存在,所以在访问共享资源时不加锁,而是在更新数据时判断共享资源是否被其他线程修改(根据版本号/时间戳),如果没有则修改成功;否则进行重试或报错。
- 悲观锁:在访问资源时,任务竞争总是存在,所以在访问共享资源时进行加锁。
- 共享锁:访问共享资源时,共享锁可以被多个线程共同持有。
- 排它锁:访问共享资源时,锁只能被一个线程所持有。
锁的实现
- 乐观锁:java中乐观锁利用CAS(毕竟并替换)思想来实现。
- AtomicInteger
- AtomicLong
- 悲观锁:
- synchronized
- Lock
- 共享锁:
- ReentrantReadWriteLock:读写锁中的读锁就是典型的共享锁
- 排它锁:
- ReentrantReadWriteLock:读写锁中的写锁就是典型的排它锁
- synchronized
- ReentrantLock