tryLock() 提供非阻塞加锁,立即返回获取结果,避免线程阻塞;带超时的 tryLock 可在指定时间内尝试获取锁,支持中断响应;需手动释放锁且仅在获取锁后调用 unlock();适用于快速失败、定时任务及防死锁场景。

在Java中,ReentrantLock 提供了比 synchronized 更灵活的锁机制,其中 tryLock() 方法是实现非阻塞式加锁的关键。它允许线程尝试获取锁,如果锁不可用,不会一直等待,而是立即返回或在指定时间内等待后返回,避免线程无限期阻塞。
1. tryLock() 的基本用法
无参的 tryLock() 方法会立即尝试获取锁:
- 如果当前线程成功获取锁,返回 true。
- 如果锁已被其他线程持有,立即返回 false,不会阻塞。
适用于需要快速失败、避免等待的场景。
ReentrantLock lock = new ReentrantLock();
if (lock.tryLock()) {
try {
// 执行临界区代码
System.out.println("成功获取锁,执行任务");
} finally {
lock.unlock(); // 必须手动释放锁
}
} else {
System.out.println("未能获取锁,跳过执行");
}
2. 带超时的 tryLock(long time, TimeUnit unit)
该版本允许线程在指定时间内尝试获取锁:
免费 盛世企业网站管理系统(SnSee)系统完全免费使用,无任何功能模块使用限制,在使用过程中如遇到相关问题可以去官方论坛参与讨论。开源 系统Web代码完全开源,在您使用过程中可以根据自已实际情况加以调整或修改,完全可以满足您的需求。强大且灵活 独创的多语言功能,可以直接在后台自由设定语言版本,其语言版本不限数量,可根据自已需要进行任意设置;系统各模块可在后台自由设置及开启;强大且适用的后台管理支
立即学习“Java免费学习笔记(深入)”;
- 在超时时间内成功获取锁,返回 true。
- 超时仍未获取到锁,返回 false。
- 在等待过程中被中断,会抛出 InterruptedException(需声明异常)。
ReentrantLock lock = new ReentrantLock();
try {
if (lock.tryLock(3, TimeUnit.SECONDS)) {
try {
System.out.println("在3秒内获取到锁");
// 模拟耗时操作
Thread.sleep(2000);
} finally {
lock.unlock();
}
} else {
System.out.println("等待3秒后仍未获取到锁");
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
System.out.println("线程在等待锁时被中断");
}
3. 使用 tryLock 的注意事项
使用 tryLock 时需注意以下几点:
- 必须手动释放锁:与 synchronized 不同,ReentrantLock 必须在 finally 块中调用 unlock(),否则可能导致死锁。
- 避免在未获取锁的情况下调用 unlock:只有 tryLock 返回 true 时才应释放锁。
- 可重入性依然有效:同一个线程多次调用 tryLock() 在已持有锁的情况下仍会成功(前提是之前已通过 tryLock 或 lock 获取)。
- 公平性影响行为:如果 ReentrantLock 设置为公平模式(new ReentrantLock(true)),tryLock 可能更难成功,因为要遵循等待队列顺序。
4. 典型应用场景
tryLock 特别适合以下情况:
- 定时任务调度器中防止多个实例同时运行。
- 资源争抢时快速失败,转而执行备选逻辑。
- 避免死锁的尝试性加锁,比如按不同顺序获取多个锁时。









