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. OC基础 - iOS在枚举赋值时为何采用左移格式

    枚举值 1 - iOS 枚举成员在赋值时往往是如下模式:左移对齐 2 - 为何这般设计 ?其一提高了阅读性:其二便于计算,能够更好的表达枚举值的含义 1 #import "ViewContr ...

  2. 直接使用Arrays.asList()转数组,转变类型实际为AbstractList

    1.直接将数组转换为list时List的类型为AbstractList public static void main(String[] args) { String[] arr = {"A ...

  3. gateway 网关接口防篡改验签

    gateway 网关接口防篡改验签 背景:为了尽可能降低接口在传输过程中,被抓包然后篡改接口内的参数的可能,我们可以考虑对接口的所有入参做签名验证,后端在网关依照相同的算法生成签名做匹配,不能匹配的返 ...

  4. python爬虫--房产数据爬取并保存本地

    import requestsimport csvfrom bs4 import BeautifulSoupheaders={'user-agent':'Mozilla/5.0 (Windows NT ...

  5. docker方式安装awvs和nessus渗透工具

    docker-compose.yaml文件 version: '2' services: awvsnessus: image: leishianquan/awvs-nessus:v4 environm ...

  6. java第五周学习情况

    这个星期主要是在读<大道至简>这本书,话说这本书确实还行啊.看完之后懂得了很多东西,前天写了一篇读后感,把自己的感想记了下来,以后有机会可以再看一遍.然后就是一些Java的相关知识了.也没 ...

  7. I2C总线简介-转载

    I2C总线简介 - 立创社区 (szlcsc.com) 简介 NXP半导体(原Philips半导体)于20多年前发明了一种简单的双向二线制串行通信总线,这个总线这个总线被称为IIC.Inter-IC或 ...

  8. js已知多边形坐标点,求多边形的中心点坐标

    你需要传入的数据类型如下: // 取面对象 中心点 var calculateCenter = function (lnglatarr) { var total = lnglatarr.length; ...

  9. centos-7部署kafka-v2.13.3.0.1集群

    1.部署测试机器规划 ip         kafka 版本   zookeeper 版本 192.168.113.132        v2.13.3.0.1 v3.6.3 192.168.113. ...

  10. 【2020NIO.AC省选模拟#10】C. 寄蒜几盒

    题目链接 原题解: 可以发现,假设我们把凸多边形看做障碍,一个点没有被染色当且仅当在它的位置上能看到凸多边形任意两条相对的边中的一条(也就是能看到至少$\dfrac{n}{2}$条边). 对于每个询问 ...