热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

Java锁机制Lock用法示例

这篇文章主要介绍了Java锁机制Lock用法,结合具体实例形式分析了Java锁机制的相关上锁、释放锁、隐式锁、显式锁等概念与使用技巧,需要的朋友可以参考下

本文实例讲述了Java锁机制Lock用法。分享给大家供大家参考,具体如下:

package com.expgiga.JUC;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
 * 一、用于解决多线程安全问题的方式:
 * 1.同步代码块 synchronized 隐式锁
 * 2.同步方法 synchronized 隐式锁
 * 3.同步锁Lock (jdk1.5以后) 显示锁
 * 注意:显示锁,需要通过lock()方式上锁,必须通过unlock()方式进行释放锁
 */
public class TestLock {
  public static void main(String[] args) {
    Ticket ticket = new Ticket();
    new Thread(ticket, "1号窗口").start();
    new Thread(ticket, "2号窗口").start();
    new Thread(ticket, "3号窗口").start();
  }
}
class Ticket implements Runnable {
  private int tick = 100;
  private Lock lock = new ReentrantLock();
  @Override
  public void run() {
    while (true) {
      lock.lock();
      try {
        if (tick > 0) {
          try {
            Thread.sleep(200);
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
          System.out.println(Thread.currentThread().getName() + " 完成售票,余票为 " + --tick);
        }
      } finally {
        lock.unlock();
      }
    }
  }
}

运行结果:

1号窗口 完成售票,余票为 99
2号窗口 完成售票,余票为 98
2号窗口 完成售票,余票为 97
2号窗口 完成售票,余票为 96
2号窗口 完成售票,余票为 95
3号窗口 完成售票,余票为 94
1号窗口 完成售票,余票为 93
1号窗口 完成售票,余票为 92
1号窗口 完成售票,余票为 91
1号窗口 完成售票,余票为 90
1号窗口 完成售票,余票为 89
1号窗口 完成售票,余票为 88
1号窗口 完成售票,余票为 87
1号窗口 完成售票,余票为 86
2号窗口 完成售票,余票为 85
3号窗口 完成售票,余票为 84
1号窗口 完成售票,余票为 83
2号窗口 完成售票,余票为 82
3号窗口 完成售票,余票为 81
1号窗口 完成售票,余票为 80
1号窗口 完成售票,余票为 79
1号窗口 完成售票,余票为 78
1号窗口 完成售票,余票为 77
1号窗口 完成售票,余票为 76
1号窗口 完成售票,余票为 75
1号窗口 完成售票,余票为 74
1号窗口 完成售票,余票为 73
1号窗口 完成售票,余票为 72
2号窗口 完成售票,余票为 71
2号窗口 完成售票,余票为 70
2号窗口 完成售票,余票为 69
2号窗口 完成售票,余票为 68
3号窗口 完成售票,余票为 67
1号窗口 完成售票,余票为 66
1号窗口 完成售票,余票为 65
1号窗口 完成售票,余票为 64
1号窗口 完成售票,余票为 63
1号窗口 完成售票,余票为 62
1号窗口 完成售票,余票为 61
2号窗口 完成售票,余票为 60
2号窗口 完成售票,余票为 59
3号窗口 完成售票,余票为 58
3号窗口 完成售票,余票为 57
1号窗口 完成售票,余票为 56
1号窗口 完成售票,余票为 55
2号窗口 完成售票,余票为 54
2号窗口 完成售票,余票为 53
2号窗口 完成售票,余票为 52
3号窗口 完成售票,余票为 51
1号窗口 完成售票,余票为 50
1号窗口 完成售票,余票为 49
1号窗口 完成售票,余票为 48
1号窗口 完成售票,余票为 47
1号窗口 完成售票,余票为 46
1号窗口 完成售票,余票为 45
2号窗口 完成售票,余票为 44
3号窗口 完成售票,余票为 43
3号窗口 完成售票,余票为 42
3号窗口 完成售票,余票为 41
3号窗口 完成售票,余票为 40
3号窗口 完成售票,余票为 39
1号窗口 完成售票,余票为 38
2号窗口 完成售票,余票为 37
2号窗口 完成售票,余票为 36
2号窗口 完成售票,余票为 35
2号窗口 完成售票,余票为 34
2号窗口 完成售票,余票为 33
2号窗口 完成售票,余票为 32
2号窗口 完成售票,余票为 31
3号窗口 完成售票,余票为 30
1号窗口 完成售票,余票为 29
1号窗口 完成售票,余票为 28
1号窗口 完成售票,余票为 27
1号窗口 完成售票,余票为 26
1号窗口 完成售票,余票为 25
1号窗口 完成售票,余票为 24
1号窗口 完成售票,余票为 23
1号窗口 完成售票,余票为 22
1号窗口 完成售票,余票为 21
1号窗口 完成售票,余票为 20
1号窗口 完成售票,余票为 19
1号窗口 完成售票,余票为 18
1号窗口 完成售票,余票为 17
1号窗口 完成售票,余票为 16
1号窗口 完成售票,余票为 15
2号窗口 完成售票,余票为 14
2号窗口 完成售票,余票为 13
2号窗口 完成售票,余票为 12
3号窗口 完成售票,余票为 11
3号窗口 完成售票,余票为 10
3号窗口 完成售票,余票为 9
1号窗口 完成售票,余票为 8
1号窗口 完成售票,余票为 7
1号窗口 完成售票,余票为 6
1号窗口 完成售票,余票为 5
2号窗口 完成售票,余票为 4
3号窗口 完成售票,余票为 3
1号窗口 完成售票,余票为 2
2号窗口 完成售票,余票为 1
2号窗口 完成售票,余票为 0

更多java相关内容感兴趣的读者可查看本站专题:《Java进程与线程操作技巧总结》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。


推荐阅读
  • 兆芯X86 CPU架构的演进与现状(国产CPU系列)
    本文详细介绍了兆芯X86 CPU架构的发展历程,从公司成立背景到关键技术授权,再到具体芯片架构的演进,全面解析了兆芯在国产CPU领域的贡献与挑战。 ... [详细]
  • 2020年9月15日,Oracle正式发布了最新的JDK 15版本。本次更新带来了许多新特性,包括隐藏类、EdDSA签名算法、模式匹配、记录类、封闭类和文本块等。 ... [详细]
  • 高端存储技术演进与趋势
    本文探讨了高端存储技术的发展趋势,包括松耦合架构、虚拟化、高性能、高安全性和智能化等方面。同时,分析了全闪存阵列和中端存储集群对高端存储市场的冲击,以及高端存储在不同应用场景中的发展趋势。 ... [详细]
  • 本文介绍如何使用OpenCV和线性支持向量机(SVM)模型来开发一个简单的人脸识别系统,特别关注在只有一个用户数据集时的处理方法。 ... [详细]
  • A*算法在AI路径规划中的应用
    路径规划算法用于在地图上找到从起点到终点的最佳路径,特别是在存在障碍物的情况下。A*算法是一种高效且广泛使用的路径规划算法,适用于静态和动态环境。 ... [详细]
  • 机器学习算法:SVM(支持向量机)
    SVM算法(SupportVectorMachine,支持向量机)的核心思想有2点:1、如果数据线性可分,那么基于最大间隔的方式来确定超平面,以确保全局最优, ... [详细]
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
  • 专业人士如何做自媒体 ... [详细]
  • 本文总结了《编程珠玑》第12章关于采样问题的算法描述与改进,并提供了详细的编程实践记录。参考了其他博主的总结,链接为:http://blog.csdn.net/neicole/article/details/8518602。 ... [详细]
  • 三角测量计算三维坐标的代码_双目三维重建——层次化重建思考
    双目三维重建——层次化重建思考FesianXu2020.7.22atANTFINANCIALintern前言本文是笔者阅读[1]第10章内容的笔记,本文从宏观的角度阐 ... [详细]
  • 非计算机专业的朋友如何拿下多个Offer
    大家好,我是归辰。秋招结束后,我已顺利入职,并应公子龙的邀请,分享一些秋招面试的心得体会,希望能帮助到学弟学妹们,让他们在未来的面试中更加顺利。 ... [详细]
  • PHP实现汉诺塔算法
    昨天研究了一天汉诺塔算法都没搞懂,感觉自己智商被碾压了,还不如《猩球崛起》中的那一只猩猩!!!起源传说最早发明这个问题的人是法国数学家『爱德华·卢卡斯』。在世界中心贝拿勒斯(在印度 ... [详细]
  • 本文介绍了如何通过路由汇总和无类域间路由(CIDR)技术来优化路由表,减少路由条目数量,提高网络效率。具体案例展示了路由汇总的实现方法及其对网络性能的影响。 ... [详细]
  • 双指针法在链表问题中应用广泛,能够高效解决多种经典问题,如合并两个有序链表、合并多个有序链表、查找倒数第k个节点等。本文将详细介绍这些应用场景及其解决方案。 ... [详细]
  • 本文介绍了如何使用Visual Studio Code、Sublime Text等编辑器批量删除MATLAB代码中的注释和空行,同时提供了一些高级技巧以确保代码的整洁。 ... [详细]
author-avatar
王老虎在江湖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有