多线程学习之锁的学习

一、两种锁: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只提供了非公平锁(公平锁,可以按顺序依次进行抢锁)

五、死锁的查找指令多线程学习之锁的学习

六、反编译指令

多线程学习之锁的学习