当前位置: 首页 > wzjs >正文

那个网站教你做毕设的seo是什么服务

那个网站教你做毕设的,seo是什么服务,摄影公司网站,wordpress 清除草稿ReentrantLock类详解 1. 核心概念 ReentrantLock 是Java中基于 java.util.concurrent.locks.Lock 接口实现的可重入互斥锁,提供比 synchronized 更灵活的锁控制机制。关键特性包括: 可重入性:同一线程可多次获取同一把锁。公平性选择&#…

ReentrantLock类详解


1. 核心概念

ReentrantLock 是Java中基于 java.util.concurrent.locks.Lock 接口实现的可重入互斥锁,提供比 synchronized 更灵活的锁控制机制。关键特性包括:

  • 可重入性:同一线程可多次获取同一把锁。
  • 公平性选择:支持公平锁(先请求先获取)和非公平锁(默认,允许插队)。
  • 可中断锁获取:线程等待锁时可响应中断。
  • 超时尝试锁:指定时间内尝试获取锁,避免无限等待。

2. 核心方法与使用

(1) 基础用法
import java.util.concurrent.locks.ReentrantLock;public class ReentrantLockDemo {private final ReentrantLock lock = new ReentrantLock();public void safeMethod() {lock.lock();  // 获取锁try {// 临界区代码System.out.println("线程安全操作");} finally {lock.unlock();  // 必须手动释放锁}}
}
  • 关键点
    • 必须使用 try-finally 确保锁的释放,防止死锁。
    • 锁的获取与释放必须成对出现,否则导致其他线程永久阻塞。

(2) 高级方法
方法作用
boolean tryLock()尝试非阻塞获取锁,成功返回 true,失败立即返回 false
boolean tryLock(long timeout, TimeUnit unit)超时等待获取锁,超时后返回 false
void lockInterruptibly()可中断地获取锁,等待过程中可响应中断。
boolean isHeldByCurrentThread()判断当前线程是否持有锁。
int getHoldCount()返回当前线程持有该锁的次数(重入次数)。

3. 公平锁与非公平锁

(1) 构造函数
// 默认非公平锁(性能更高,允许线程插队)
ReentrantLock nonFairLock = new ReentrantLock(); // 公平锁(按请求顺序分配锁,减少线程饥饿)
ReentrantLock fairLock = new ReentrantLock(true); 
(2) 对比
特性非公平锁公平锁
性能高(减少线程切换开销)低(需维护等待队列)
线程饥饿可能发生(新线程可能插队)避免线程饥饿
适用场景高并发、锁持有时间短严格要求顺序的业务(如订单处理)

4. 与synchronized的对比

对比项ReentrantLocksynchronized
锁获取方式显式调用 lock()unlock()隐式获取和释放(代码块或方法)
可中断性支持(lockInterruptibly()不支持
超时机制支持(tryLock(timeout)不支持
公平性可配置仅非公平
锁绑定条件支持多个 Condition一个对象只能绑定一个等待队列
性能高并发下更优优化后接近(低竞争场景更简单)

5. Condition条件变量

Condition 用于替代 Object.wait()/notify(),实现更精准的线程等待与唤醒。

(1) 基本用法
private final ReentrantLock lock = new ReentrantLock();
private final Condition condition = lock.newCondition();public void await() throws InterruptedException {lock.lock();try {condition.await();  // 释放锁并等待} finally {lock.unlock();}
}public void signal() {lock.lock();try {condition.signal(); // 唤醒一个等待线程} finally {lock.unlock();}
}
(2) 多条件示例(生产者-消费者模型)
private final Condition notFull = lock.newCondition();  // 队列未满条件
private final Condition notEmpty = lock.newCondition(); // 队列非空条件// 生产者
public void put(Object item) throws InterruptedException {lock.lock();try {while (queue.isFull()) {notFull.await(); // 等待队列未满}queue.add(item);notEmpty.signal();  // 唤醒消费者} finally {lock.unlock();}
}// 消费者
public Object take() throws InterruptedException {lock.lock();try {while (queue.isEmpty()) {notEmpty.await(); // 等待队列非空}Object item = queue.remove();notFull.signal();    // 唤醒生产者return item;} finally {lock.unlock();}
}

6. 最佳实践与注意事项

  1. 避免锁泄漏:确保 unlock()finally 块中执行。
  2. 减少锁持有时间:仅在必要代码段加锁,提升并发性能。
  3. 优先使用非公平锁:除非业务严格要求顺序。
  4. 合理使用Condition:避免复杂条件逻辑导致代码难以维护。

总结

ReentrantLock 提供了比 synchronized 更精细的锁控制能力,适用于高并发、需要灵活锁管理的场景。通过结合 Condition 和公平性策略,可以实现复杂的线程协作逻辑。然而,其手动管理锁的特性也要求开发者更谨慎地编写代码,避免死锁和资源泄漏。

http://www.dtcms.com/wzjs/450360.html

相关文章:

  • 网页微信版收藏健山东seo
  • 做购物网站的开题报告seo教程seo教程
  • 虚拟机做网站有用吗互动营销名词解释
  • 哪里网站建设公司好曹操博客seo
  • 什么网站可以做翻译兼职seo排名优化公司
  • 访问网站的原理常用的搜索引擎有哪些?
  • 表白网站是怎么做的网站推广关键词工具
  • 网站开发职业定位产品推广方式
  • 红桥网站建设公司站长工具ip查询
  • 江镇做包子网站新网站百度seo如何做
  • 制作网站的模板下载软件百度新闻搜索
  • 一台ip做两个网站google登录入口
  • 网站建设 010关键词推广优化外包
  • 广西网站建设运营费用电商平台哪个最好最可靠
  • 玉林建设工程信息网站数据统计网站有哪些
  • 万户网站协作管理系统天津seo霸屏
  • 网站开发建设书籍推荐网站制作流程是什么
  • win8风格手机网站模板广州灰色优化网络公司
  • 广州讯优网站建设公司怎么样站长之家排行榜
  • 漳州手机网站建设公司哪家好中国知名网站排行榜
  • 个人设计网站论文摘要steam交易链接怎么获取
  • wordpress8小时前浙江seo博客
  • 网站优化哪里可以做自媒体发布平台
  • 用java做网站推荐书籍百度新闻官网首页
  • 应价交易系统网站开发广告联盟接单平台
  • 安阳 做网站世界十大网站排名
  • 电脑有固定IP 做网站专门做排名的软件
  • 建网站多少钱一个月百度权重工具
  • 企业网站的规划与设计百度指数分析数据
  • 楚雄市城乡建设局网站百度的网址是什么