Synchronized 和 Lock

1、原始构成

Synchronized 是关键字属于JVM层面 (代码中以蓝色字体呈现)
monitorenter 、monitorexit
Lock 是具体类(java.util.concurrent.locks.lock)是api层面的锁

2、使用方法

Synchronized 不需要用户手动释放锁,当synchronized代码执行完后系统会自动让线程释放对锁的占用
ReentrantLock 需要用户手动释放锁 如果没有释放,就会导致死锁
需要lock() 和 unlock()方法配合try/finally语句块来完成 (Lock需要在while中使用,不能在if里面使用)

3、等待是否可中断

Synchronized 不可中断,除非抛出异常 或 正常运行完成
ReentrantLock 可中断
1>设置超时方法 tryLock(long timeout, TimeUnit unit)
2>lockInterruptibly() 放代码块中,调用 interrup() 方法可中断

4、加锁是否公平

Synchronized 非公平锁
ReentrantLock 两者都可以,默认非公平锁 (可重入锁) 构造方法可以传入 boolean值,true公平锁 false非公平锁

5、锁绑定多个条件Condition

Synchronized 没有
ReentrantLock 用来实现分组唤醒需要唤醒的线程们,可以精确唤醒 而synchronized要么随机唤醒一个,要么全部唤醒

题目:多线程之间顺序调用,实现A->b->C三个线程启动,要求如下:

AA打印5次,BB打印10次,CC打印15次 重复10次

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; /**
* @Author: LeavesCai7
* @Date: 2021/01/22 11:29
* 题目:多线程之间顺序调用,实现A->b->C三个线程启动,要求如下:
* AA打印5次,BB打印10次,CC打印15次 重复10次
* ReentrantLock
*/ class shareResource{
private int num = 1; //A:1 B:2 C:3
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 (num != 1){
c1.await();
} //干活
for (int i =1;i<=5;i++){
System.out.println(Thread.currentThread().getName() + "\t" + i);
} //通知
num = 2;
c2.signal(); }catch (Exception e){
e.printStackTrace();
}finally {
lock.unlock();
}
}
public void print10(){
lock.lock();
try{ //判断
while (num != 2){
c1.await();
} //干活
for (int i =1;i<=10;i++){
System.out.println(Thread.currentThread().getName() + "\t" + i);
} //通知
num = 3;
c3.signal(); }catch (Exception e){
e.printStackTrace();
}finally {
lock.unlock();
}
} public void print15() {
lock.lock();
try { //判断
while (num != 3) {
c1.await();
} //干活
for (int i = 1; i <= 15; i++) {
System.out.println(Thread.currentThread().getName() + "\t" + i);
} //通知
num = 1;
c3.signal(); } catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
} public class SyncAndReentrantLockDemo {
public static void main(String[] args) {
shareResource shareResource = new shareResource(); new Thread(() -> {
for (int i = 0; i <= 10; i++) {
shareResource.print5();
}
},"A").start(); new Thread(() -> {
for (int i = 0; i <= 10; i++) {
shareResource.print10();
}
},"B").start(); new Thread(() -> {
for (int i = 0; i <= 10; i++) {
shareResource.print15();
}
},"C").start(); }
}

Synchronized和Lock有什么区别?用Lock有什么好处?的更多相关文章

  1. synchronized 和 Lock 有什么区别?(未完成)

    synchronized 和 Lock 有什么区别?(未完成)

  2. 用阻塞队列实现一个生产者消费者模型?synchronized和lock有什么区别?

    多线程当中的阻塞队列 主要实现类有 ArrayBlockingQueue是一个基于数组结构的有界阻塞队列,此队列按FIFO原则对元素进行排序 LinkedBlockingQueue是一个基于链表结构的 ...

  3. synchronized和lock有什么区别?

    一.原始构成 synchronized是关键字属于JVM层面,monitorenter(底层是通过monitor对象来完成,其实wait/notify等方法也依赖monitor对象只有在同步代码块和同 ...

  4. java面试-synchronized与lock有什么区别?

    1.原始构成: synchronized是关键字,属于JVM层面,底层是由一对monitorenter和monitorexit指令实现的. ReentrantLock是一个具体类,是API层面的锁. ...

  5. Synchronized和Lock, 以及自旋锁 Spin Lock, Ticket Spin Lock, MCS Spin Lock, CLH Spin Lock

    Synchronized和Lock synchronized是一个关键字, Lock是一个接口, 对应有多种实现. 使用synchronized进行同步和使用Lock进行同步的区别 使用synchro ...

  6. C#中Monitor对象与Lock关键字的区别分析

    这篇文章主要介绍了C#中Monitor对象与Lock关键字的区别,需要的朋友可以参考下 Monitor对象 1.Monitor.Enter(object)方法是获取 锁,Monitor.Exit(ob ...

  7. 转:C#中Monitor对象与Lock关键字的区别分析

    Monitor对象1.Monitor.Enter(object)方法是获取 锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取 ...

  8. 【JUC】synchronizated和lock的区别&新lock的优势

    原始构成 synchronized是关键字,属于JVM层面 javap -c 的结果显示 synchronized是可重入锁 11:是正常退出 17:是异常退出[保证不产生死锁和底层故障] Lock是 ...

  9. ReentrantLock可重入锁lock,tryLock的区别

    void lock(); Acquires the lock. Acquires the lock if it is not held by another thread and returns im ...

  10. volatile和synchronized实现内存可见性的区别

    先看看synchronized实现内存可见性 加锁(synchronized同步)的功能不仅仅局限于互斥行为,同时还存在另外一个重要的方面:内存可见性.我们不仅希望防止某个线程正在使用对象状态而另一个 ...

随机推荐

  1. 询问chatGPT的一些问题

  2. ES可视化平台kibana安装和使用

    一.kibana介绍 Kibana是一个针对Elasticsearch的开源分析及可视化平台,用来搜索.查看交互存储在Elasticsearch索引中的数据. 二.kibana安装 1.解压 tar ...

  3. tomcat反向代理,监控,性能优化详细步骤

    第1章 tomcat简介Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache,Sun和其他一些公司及个人共同 ...

  4. 备份Cisco交换机设备配置

    需求: 备份网络核心设备配置 工具: 1.3CDaemon软件,用于配置TFTP服务器 链接:http://www.china-ccie.com/download/3CDaemon/3CDaemon. ...

  5. Django Rest Frame work 如何使用serializers序列化函数新手教程

    Django Rest Frame work 如何使用serializers序列化       Django Rest Framework提供了serializers模块,用于序列化和反序列化模型实例 ...

  6. xen虚拟化技术完全导读_pdf

    链接:https://pan.baidu.com/s/1W3qTgj8ygkdiz7nln802Xw 提取码:g9k3

  7. pat乙级1011 A+B 和C

    #include<stdio.h> #include<stdlib.h> #include<string.h> #include<math.h> int ...

  8. python连接Oracel、postgreSQL、SQLserver、Mysql、mongodb、redis等常用数据库方法汇总

    python对接常用数据库 python有着极其丰富的第三方的库,如此强大的python语言操作各大数据库,不管你使用的关系型数据库是oracle,mysql, sqlserver,还是关系型数据库r ...

  9. 微信小程序 - canvas实现多行文本 ,实现文本断行

    1.canvas绘制文本坑点 绘制的文本不管多长,永远只有一行,不会断行. 2.解决思路 根据每行文本字数来断行,超出的就向下排列. 由于 canvas绘制文本的语法如下: context.fillT ...

  10. PostProcess

    后处理器: AutowiredAnnotationBeanPostProcess.class 可以处理@Autowired.@Value 如何注册:context.registerBean(xxx.c ...