大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE稳定放心使用
业务场景
对于某些并发业务场景,我们可能想保证同一时刻只有一个线程在执行某一方法。
例如:对于缓存的初始化工作,此时我们可以使用tryLock()
方法对代码进行上锁,只有拿到锁的线程可以执行操作,而其他线程则只会在进行一次尝试后返回false。
方法说明
Acquires the lock only if it is not held by another thread at the time of invocation.
只有在调用时它是空闲的才能获取锁。
获取锁定(如果可用)并立即返回值true 。 如果锁定不可用,则此方法将立即返回值false 。
用法
public static void main(String[] args) {
ReentrantLock lock = new ReentrantLock();
new Thread(() -> {
if (lock.tryLock()) {
System.out.println("A拿到锁了");
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
} else {
System.out.println("A没有拿到锁");
}
}, "MyThread-A").start();
new Thread(() -> {
if (lock.tryLock()) {
System.out.println("B拿到锁了");
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
lock.unlock();
}
} else {
System.out.println("B没有拿到锁");
}
}, "MyThread-B").start();
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/181771.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...