java锁机制

整理一下java的锁机制。java

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

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

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

2.重入锁线程

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

3.自旋锁数据

是指当一个线程在获取锁的时候,若是锁已经被其它线程获取,那么该线程将循环等待,而后不断的判断锁是否可以被成功获取,直到获取到锁才会退出循环。兼容

4.读写锁di

读读兼容,读写兼容,写读不兼容,写写不兼容阻塞

5.CAS无锁

campare and swap 。 首先会拿出一个版本,而后操做,写入数据库时会与数据库的版本比对,若是不一致就写入失败。

6.分布式锁

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

相关文章
相关标签/搜索