多线程之锁
线程锁分两种:内置锁(synchronized)和显式锁(ReentrantLock)
简单对比:
主要相同点:Lock能完成synchronized所实现的所有功能
主要不同点:Lock有比synchronized更精确的线程语义和更好的性能,当许多线程都在争用同一个锁时,使用 ReentrantLock 的总体开支通常要比 synchronized 少得多。
synchronized会自动释放锁,而Lock一定要求程序员手工释放,为了防止忘记释放锁,一般在finally从句中释放。
Synchronized不能设置等待时间,所以如果等待的资源一直被占用,可能会出现死锁.
ReentrantLock会灵活一点,可以设置等待的时间,如果等待的时间到了,就会去做其它的任务.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | package com.wowowo.lock; public class SellTicket implements Runnable { private static int tickets= 100 ; public void run() { while ( true ) { /* //隐士锁 内置锁 方式1 锁住代码块 synchronized (this) { if(tickets>0) { System.out.println(Thread.currentThread().getName()+"售出第..."+tickets+"...张票"); tickets--; try { Thread.sleep(10); //休眠 10毫秒 } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }*/ //方式 2 sellTicket(); } } //方式2 锁住方法(成员方法或静态方法) public synchronized void sellTicket() { if (tickets> 0 ) { System.out.println(Thread.currentThread().getName()+ "售出第..." +tickets+ "...张票" ); tickets--; try { Thread.sleep( 10 ); //休眠 10毫秒 } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)