通过实例解析synchronized和lock区别
1,原始构成
synchronized是关键字,属于JVM层面,通过wait,notify和notifyAll来调度线程。
Lock是具体类,是api层面的锁。
2,使用方法
synchronized不需要用户手动去释放锁,当synchronized代码执行完后,系统会自动释放锁。
Lock需要用户手动释放锁,否则会出现死锁现象。需要lock和unlock配合try/finally语句块来完成。
3,等待是否中断
synchronized不可中断,除非抛出异常或者正常运行完毕。
Lock可中断,可以设置超时方法或者调用中断方法。
4,加锁是否公平
synchronized非公平锁。
Lock默认非公平锁,可指定为公平锁。
5,锁绑定多个条件condition
synchronized没有。
Lock用来分组唤醒需要唤醒的线程,可以精确唤醒,而不是像synchronized一样要么随机唤醒一个线程,要么全部唤醒。
Demo:练习
多线程之间按顺序调用,实现A->B->C三个线程启动,要求:AA打印5次,BB打印10次,CC打印15次,重复10遍。
packagecom.demo.lock;
importjava.util.concurrent.TimeUnit;
importjava.util.concurrent.locks.Condition;
importjava.util.concurrent.locks.Lock;
importjava.util.concurrent.locks.ReentrantLock;
classShareResource{
intnumber=1;
privateLocklock=newReentrantLock();
privateConditionc1=lock.newCondition();
privateConditionc2=lock.newCondition();
privateConditionc3=lock.newCondition();
publicvoidprint5(){
lock.lock();
try{
while(number!=1){
c1.await();
}
for(inti=1;i<=5;i++){
System.out.println(Thread.currentThread().getName()+"\t"+i);
}
number=2;
c2.signal();
}catch(Exceptione){
e.printStackTrace();
}finally{
lock.unlock();
}
}
publicvoidprint10(){
lock.lock();
try{
while(number!=2){
c2.await();
}
for(inti=1;i<=10;i++){
System.out.println(Thread.currentThread().getName()+"\t"+i);
}
number=3;
c3.signal();
}catch(Exceptione){
e.printStackTrace();
}finally{
lock.unlock();
}
}
publicvoidprint15(){
lock.lock();
try{
while(number!=3){
c3.await();
}
for(inti=1;i<=15;i++){
System.out.println(Thread.currentThread().getName()+"\t"+i);
}
number=1;
c1.signal();
}catch(Exceptione){
e.printStackTrace();
}finally{
lock.unlock();
}
}
}
publicclassTestReentrantLock{
publicstaticvoidmain(String[]args){
ShareResourceshareResource=newShareResource();
newThread(()->{
for(inti=1;i<=10;i++){
shareResource.print5();
}
},"AA").start();
newThread(()->{
for(inti=1;i<=10;i++){
shareResource.print10();
}
},"BB").start();
newThread(()->{
for(inti=1;i<=10;i++){
shareResource.print15();
}
},"CC").start();
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。