整理一下java的锁机制。
1.乐观锁与悲观锁(排他锁)
悲观锁:每次拿数据的时候,都会上锁
乐观锁:拿数据时不会加锁,但是每次操作数据的时候会先比较版本。(与CAS无锁机制相同)
2.重入锁
锁传递,任意线程在获取到锁之后,再次获取该锁而不会被该锁所阻塞。Lock和synchronized都是重入锁.
3.自旋锁
是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环。
4.读写锁
读读兼容,读写兼容,写读不兼容,写写不兼容
5.CAS无锁
campare and swap 。 首先会拿出一个版本,然后操作,写入数据库时会与数据库的版本比对,如果不一致就写入失败。
6.分布式锁
不同系统之间使用的锁,只用过redis 实现