栗子来源:https://blog.csdn.net/wenzhi20102321/article/details/52524545
首先对java中同步锁与互斥锁进行区分,主要来源于知乎中的大佬总结如下:
1.锁的概念
锁的目的就是避免多个线程对同一个共享的数据并发修改带来的数据混乱。
锁的实现要处理的大概就只有这4个问题:(知乎大宽宽的回答,非本人观点)
- “谁拿到了锁“这个信息存哪里(可以是当前class,当前instance的markword,还可以是某个具体的Lock的实例)
- 谁能抢到锁的规则(只能一个人抢到 - Mutex;能抢有限多个数量 - Semaphore;自己可以反复抢 - 重入锁;读可以反复抢到但是写独占 - 读写锁……)
- 抢不到时怎么办(抢不到玩命抢;抢不到暂时睡着,等一段时间再试/等通知再试;或者二者的结合,先玩命抢几次,还没抢到就睡着)
- 如果锁被释放了还有其他等待锁的怎么办(不管,让等的线程通过超时机制自己抢;按照一定规则通知某一个等待的线程;通知所有线程唤醒他们,让他们一起抢……)
2.互斥与同步
互斥锁与同步锁的区别: