多线程学习之锁的学习
多线程学习之锁的学习
- 一、两种锁:reentrantlock和synchronize
- 二、reentrantlock的运用
- 三、synchronize的运用
- 四、两者的区别
- 五、死锁的查找指令![在这里插入图片描述](https://img-blog.csdnimg.cn/20200213202201508.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2NvZGVzd2VldHBvdGF0bw==,size_16,color_FFFFFF,t_70)
- 六、反编译指令
一、两种锁:reentrantlock和synchronize
二、reentrantlock的运用
在finally的代码块中进行解锁
三、synchronize的运用
四、两者的区别
1.当synchornized关键字作用在静态方法上时,其称之为类锁。当synchornized作用在非静态方法上时,其称之为对象锁。thread.sleep方法不会释放锁。
2.synchronized与reentrantlock
相同点:
a.都是用于多线程中对资源加锁,控制代码同一时间只有单个 线程现在只想
b.当一个线程获取了锁,其他线程均需要阻塞等待
c.均为可重入锁
不同点:
a.synchronized是Java语言的关键字,由虚拟机字节码指令实现。而reentrantlock是java sdk提供的API级别的实现
b.synchronize可以在方法级别加锁,reentrantlock则不行
c.reentrantlock可以通过方法trylock等待指定时间的锁,超时则返回。synchronizedze则 不行
d.reentrantlock提供了公平锁与非公平锁,而synchronized只提供了非公平锁(公平锁,可以按顺序依次进行抢锁)