常见锁
常见锁
基础概念:
并发(Concurrency):一个处理器“同时”处理多个任务
并行(Parallelism):多个处理器“同时”处理多个任务
互斥锁(Mutex)
同步块 synchronized block
对象锁 object.lock()
可重入锁
可重入锁,也叫做递归锁,指的是同一线程外层方法获得锁之后,内层递归方法仍然有获取该锁的代码,但不受影响。ReentrantLock和synchronized都是可重入锁。
在lock方法内,应验证线程是否为已经获得锁的线程。当unlock()第一次调用时,实际上不应释放锁。(采用计数进行统计)
可重入锁最大的特点是避免死锁。
1 | public class Test implements Runnable{ |
1 | 返回结果: |
1 | public class Test implements Runnable { |
信号量(Semaphore)
- 公平和非公平
公平信号量的效果是线程的启动顺序与调用Semaphore.acquire()顺序有关,即先启动的线程优先得到许可。
非公平信号量的效果是与线程的启动顺序与调用Semaphore.acquire()顺序无关,也就是说先启动的线程并不一定先获得许可。
- 实现原理
Semaphore是用来保护一个或者多个共享资源的访问,Semaphore内部维护了一个计数器,其值为可以访问的共享资源的个数。一个线程要访问共享资源,先获得信号量,如果信号量的计数器值大于1,意味着有共享资源可以访问,则使其计数器值减去1,再访问共享资源。
如果计数器值为0,线程进入休眠。当某个线程使用完共享资源后,释放信号量,并将信号量内部的计数器加1,之前进入休眠的线程将被唤醒并再次试图获得信号量。
乐观锁(CAS)
- ABA问题:无锁堆栈实现
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 yupaits的博客!
评论