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