javaEE多线程3

乐观锁和悲观锁

乐观锁:预估多个线程访问一个共享变量所发生冲突的概率非常小

悲观锁:预估多个线程访问一个共享变量所发生冲突的概率非常大

读写锁:把读操作和写操作分别进行加锁

读加锁和读加锁之间不互斥

读加锁和写加锁之间互斥

写加锁和写加锁之间互斥

重量级锁和轻量级锁

重量级锁:加锁、解锁的过程更低效

轻量级锁:加锁、解锁的过程更高效

自旋锁和挂起锁

自旋锁:是轻量级锁的一个典型实现,一旦锁被释放就能立即能拿到锁,但是消耗CPU的资源

挂起锁:是重量级锁的一个典型实现,锁被释放不能立马拿到锁,不消耗CPU的资源

公平锁和不公平锁

公平锁:遵守“先来后到”的规则

不公平锁:不遵守“先来后到”的规则

可重入锁和不可重入锁

可重入锁:允许一个线程多次获取同一把锁,并且不会产生死锁

不可重入锁:允许一个线程多次获取同一把锁,但是产生死锁

synchronized的特点

①既是悲观锁又是乐观锁

②既是轻量级锁,又是重量级锁

③自旋锁是轻量级锁的一种典型实现,挂起锁是重量级锁的典型实现

④不是读写锁

⑤是可重入锁

⑥是不公平锁

死锁:

①一个线程一把锁,如果是可重入锁,则不会发生死锁;如果是不可重入锁,则会发生死锁

②两个线程两把锁,就算是可重入锁,必然也会发生死锁

③线程数量越多,越容易发生死锁

死锁发生的条件:

①互斥执行:一个线程拿到一把锁之后,另一个线程不能使用

②不可抢占:一个线程拿到锁,只能自己释放,不能被其他线程使用

③请求和等待;④循环等待

如何避免出现死锁:

最简单的方法:破解循环等待这个条件

针对锁进行编号,如果需要同时获取多把锁,约定加锁顺序,务必是先对小的编号进行加锁,后对大的编号进行加锁

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值