• 系列二、Lock接口


    一、多线程编程模板

    线程        操作        资源类

    高内聚                    低耦合

    二、实现步骤

    1、创建资源类
    2、资源类里创建同步方法、同步代码块

    三、12306卖票程序

    3.1、synchronized实现

    3.1.1、Ticket

    1. /**
    2. * @Author : 一叶浮萍归大海
    3. * @Date: 2023/11/20 8:54
    4. * @Description: 资源类火车票
    5. */
    6. public class Ticket {
    7. private Integer num = 30;
    8. public synchronized void saleTicket() {
    9. if (num > 0) {
    10. System.out.println(Thread.currentThread().getName() + " 卖出第:" + (num--) + "张票,还剩下:" + num + "张票!");
    11. }
    12. }
    13. }

    3.1.2、SaleTicketSynchronizedMainApp

    1. /**
    2. * @Author : 一叶浮萍归大海
    3. * @Date: 2023/11/20 8:57
    4. * @Description: 需求:三个售票员 卖出 30张票(synchronized实现)
    5. * 多线程编程的企业级套路 + 模板:在高内聚低耦合的前提下,线程操作资源类
    6. */
    7. public class SaleTicketSynchronizedMainApp {
    8. public static void main(String[] args) {
    9. Ticket ticket = new Ticket();
    10. new Thread(() -> {for (int i = 1; i <= 40; i++) {ticket.saleTicket();}}, "A").start();
    11. new Thread(() -> {
    12. for (int i = 1; i <= 40; i++) {
    13. ticket.saleTicket();
    14. }
    15. }, "B").start();
    16. new Thread(() -> {
    17. for (int i = 1; i <= 40; i++) {
    18. ticket.saleTicket();
    19. }
    20. }, "C").start();
    21. }
    22. }

    3.1.3、结果

    3.2、Lock实现

    3.2.1、Ticket

    1. /**
    2. * @Author : 一叶浮萍归大海
    3. * @Date: 2023/11/20 8:57
    4. * @Description: 需求:三个售票员 卖出 30张票(synchronized实现)
    5. * 多线程编程的企业级套路 + 模板:在高内聚低耦合的前提下,线程操作资源类
    6. */
    7. public class SaleTicketSynchronizedMainApp {
    8. public static void main(String[] args) {
    9. Ticket ticket = new Ticket();
    10. new Thread(() -> {
    11. for (int i = 1; i <= 40; i++) {
    12. ticket.saleTicket();
    13. }
    14. }, "A").start();
    15. new Thread(() -> {
    16. for (int i = 1; i <= 40; i++) {
    17. ticket.saleTicket();
    18. }
    19. }, "B").start();
    20. new Thread(() -> {
    21. for (int i = 1; i <= 40; i++) {
    22. ticket.saleTicket();
    23. }
    24. }, "C").start();
    25. }
    26. }

    3.2.2、SaleTicketLockMainApp

    1. /**
    2. * @Author : 一叶浮萍归大海
    3. * @Date: 2023/11/20 8:57
    4. * @Description: 需求:三个售票员 卖出 30张票(Lock实现)
    5. * 多线程编程的企业级套路 + 模板:在高内聚低耦合的前提下,线程操作资源类
    6. */
    7. public class SaleTicketLockMainApp {
    8. public static void main(String[] args) {
    9. Ticket ticket = new Ticket();
    10. new Thread(() -> {
    11. for (int i = 1; i <= 40; i++) {
    12. ticket.saleTicket();
    13. }
    14. }, "AA").start();
    15. new Thread(() -> {
    16. for (int i = 1; i <= 40; i++) {
    17. ticket.saleTicket();
    18. }
    19. }, "BB").start();
    20. new Thread(() -> {
    21. for (int i = 1; i <= 40; i++) {
    22. ticket.saleTicket();
    23. }
    24. }, "CC").start();
    25. }
    26. }

    3.2.3、结果

    四、Lock

    4.1、概述

    4.2、Lock接口的实现类ReentrantLock

    4.3、如何使用ReentrantLock

    1. class X {
    2. private final ReentrantLock lock = new ReentrantLock();
    3. // ...
    4. public void m() {
    5. lock.lock(); // block until condition holds
    6. try {
    7. // ... method body
    8. } finally {
    9. lock.unlock()
    10. }
    11. }
    12. }

    4.4、synchronized VS Lock

    (1)首先synchronized是java内置的关键字,在jvm层面,Lock是个java类;
    (2)synchronized无法判断是否获取锁的状态,Lock可以判断是否获取到锁;
    (3)synchronized会自动释放锁(a 线程执行完同步代码会释放锁 ;b 线程执行过程中发生异常会释放锁),Lock需在finally中手工释放锁(unlock()释放锁),否则容易造成线程死锁;
    (4)用synchronized关键字的两个线程1和线程2,如果当前线程1获得锁,线程2等待。如果线程1阻塞,线程2则会一直等待下去,而Lock锁就不一定会等待下去,如果尝试获取不到锁,           线程可以不用一直等待就结束了;
    (5)synchronized的锁可重入、不可中断、非公平,而Lock锁可重入、可中断、可公平(两者皆可);
    (6)Lock锁适合大量同步的代码的同步问题,synchronized锁适合代码少量的同步问题;

  • 相关阅读:
    Ubuntu:解决PyCharm中不能输入中文或者输入一个中文解决方法
    IDEA项目初始化编码
    口袋参谋:如何对宝贝关键词进行词根分析?用它就对了!
    观察者模式
    一种改进的原子搜索算法-附代码
    深入理解Java内存模型JMM与volatile关键字
    【DIY小记】修复Win10启动出现蓝屏0xc0000185错误的一些方法
    Java语法1
    【二】2D测量 Metrology——add_metrology_object_rectangle2_measure()算子
    leetcode的TreeNode工具类
  • 原文地址:https://blog.csdn.net/HelloWorld20161112/article/details/134499325