整理一下java的锁机制。

1.乐观锁与悲观锁(排他锁)

悲观锁:每次拿数据的时候,都会上锁

乐观锁:拿数据时不会加锁,但是每次操作数据的时候会先比较版本。(与CAS无锁机制相同)

2.重入锁

锁传递,任意线程在获取到锁之后,再次获取该锁而不会被该锁所阻塞。Lock和synchronized都是重入锁.

3.自旋锁

是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环。

4.读写锁

读读兼容,读写兼容,写读不兼容,写写不兼容

5.CAS无锁

campare and swap 。 首先会拿出一个版本,然后操作,写入数据库时会与数据库的版本比对,如果不一致就写入失败。

6.分布式锁

不同系统之间使用的锁,只用过redis 实现

04-19 07:18