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. java script--一些冷知识

    java script--一些冷知识 目录 java script--一些冷知识 布兰登·艾奇,JavaScript 创始人 java script logo json logo json node. ...

  2. laravel视图响应

    1.输出json $data = [ 'id' => 1, 'name' => 'jack', ]; return response()->json($data); 2.重定向 // ...

  3. css - 预编译less下,解决深度选择器失效问题,完成css样式修改

    #若深度选择器有效.使用此可修改样式 /deep/ .cube-btn{ //...自定义css样式 } #深度选择器失效,则: 1.重新定义deep深度选择器 @deep:~'>>> ...

  4. redis+token实现一个账号只能一个人登录

    自己在闲着没事的时候,突然想到了这么一个小功能,于是决定练习一下,首先想到的是如果一个账号只能一个人登录,可能会出现两个情况,一种是后登录者把前者的账号顶替掉,还有一种就是后者登录的时候会有提示当前账 ...

  5. 2019-2020-1 20199318《Linux内核原理与分析》第十二周作业

    <Linux内核原理与分析> 第十二周作业 一.预备知识 Set-UID 是 Unix 系统中的一个重要的安全机制.当一个 Set-UID 程序运行的时候,它被假设为具有拥有者的权限.例如 ...

  6. Linux安装两个anaconda

    安装过程 1.安装第一个Anaconda Anaconda的官方安装网址在 https://www.continuum.io/downloads/ 安装命令: bash Anaconda3-4.3.1 ...

  7. 关于echart折线图只有2个点时的平滑曲线问题

    问题描述: 折线图,设置平滑曲线,多个点时没有问题, 可当只有两个点(数据)的时候,这时光靠 smooth: true  就不管用了. 解决方法: 还另需设置   smoothMonotone 单调性 ...

  8. (jmeter笔记)聚合报告分析

    Label:说明是请求类型,如Http, FTP等请求. #Samples:也就是图形报表中的样本数目,总共发送到服务器的样本数目. Average:也就是图形报表中的平均值,是总运行时间除以发送到服 ...

  9. Automatic Workload Repository (AWR)自动工作负载存储库

    自动工作负载存储库 (AWR)是历史性能数据的存储库,其中包括系统.会话.单个 SQL 语句.段和服务的累积统计信息. AWR 统计数据是性能调优的基础.通过自动收集用于问题检测和调整的数据库统计信息 ...

  10. mysql5.7主从多线程同步

    数据库复制的主要性能问题就是数据延时 为了优化复制性能,Mysql 5.6 引入了 "多线程复制" 这个新功能 但 5.6 中的每个线程只能处理一个数据库,所以如果只有一个数据库, ...