时间:2021-05-19
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遍。
package com.demo.lock;import java.util.concurrent.TimeUnit;import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;class ShareResource{ int number = 1; private Lock lock = new ReentrantLock(); private Condition c1 = lock.newCondition(); private Condition c2 = lock.newCondition(); private Condition c3 = lock.newCondition(); public void print5(){ lock.lock(); try { while(number!=1){ c1.await(); } for(int i=1;i<=5;i++){ System.out.println(Thread.currentThread().getName()+"\t"+i); } number = 2; c2.signal(); } catch (Exception e) { e.printStackTrace(); }finally{ lock.unlock(); } } public void print10(){ lock.lock(); try { while(number!=2){ c2.await(); } for(int i=1;i<=10;i++){ System.out.println(Thread.currentThread().getName()+"\t"+i); } number = 3; c3.signal(); } catch (Exception e) { e.printStackTrace(); }finally{ lock.unlock(); } } public void print15(){ lock.lock(); try { while(number!=3){ c3.await(); } for(int i=1;i<=15;i++){ System.out.println(Thread.currentThread().getName()+"\t"+i); } number = 1; c1.signal(); } catch (Exception e) { e.printStackTrace(); }finally{ lock.unlock(); } }}public class TestReentrantLock { public static void main(String[] args) { ShareResource shareResource = new ShareResource(); new Thread(()->{ for(int i=1;i<=10;i++){ shareResource.print5(); } },"AA").start(); new Thread(()->{ for(int i=1;i<=10;i++){ shareResource.print10(); } },"BB").start(); new Thread(()->{ for(int i=1;i<=10;i++){ shareResource.print15(); } },"CC").start(); }}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
synchronize和lock区别如下: 1、synchronized和lock的用法区别。synchronized:在需要同步的对象中加入此控制,sync
前言本文介绍了Java编程synchronized与lock的区别的相关内容,如果您对synchronized与lock不太了解,这两篇文章或许是不错的选择:J
synchronized和lock的异同如下: 1、首先synchronized是java内置关键字,在jvm层面,Lock是个java类; 2、synch
以下是本篇文章的大纲1synchronized和lock1.1synchronized的局限性1.2Lock简介2AQS3lock()与unlock()实现原理
在java多线程编程中经常volatile,有时候这个关键字和synchronized或者lock经常有人混淆,具体解析如下:在多线程的环境中会存在成员变量可见