// Java Lock 示例代码
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class Counter {
private int count = 0;
private final Lock lock = new ReentrantLock(); // 创建一个 ReentrantLock 实例
public void increment() {
lock.lock(); // 获取锁
try {
count++;
} finally {
lock.unlock(); // 确保在使用完后释放锁
}
}
public int getCount() {
return count;
}
public static void main(String[] args) throws InterruptedException {
Counter counter = new Counter();
Thread t1 = new Thread(() -> {
for (int i = 0; i < 1000; i++) {
counter.increment();
}
});
Thread t2 = new Thread(() -> {
for (int i = 0; i < 1000; i++) {
counter.increment();
}
});
t1.start();
t2.start();
t1.join();
t2.join();
System.out.println("Final count is: " + counter.getCount());
}
}
ReentrantLock:ReentrantLock 是 java.util.concurrent.locks 包中的一个类,它提供了比内置锁(即 synchronized)更灵活的锁定机制。它可以显式地获取和释放锁,并且支持公平锁、非公平锁等特性。
lock.lock() 和 lock.unlock():在访问共享资源时,必须先调用 lock.lock() 来获取锁,确保同一时间只有一个线程可以执行临界区的代码。当操作完成时,必须调用 lock.unlock() 来释放锁,以便其他线程可以获取锁并继续执行。
try-finally 块:为了确保锁一定会被释放,即使在临界区内发生异常,我们通常将 lock.unlock() 放在 finally 块中。这样可以保证无论是否发生异常,锁都会被正确释放。
多线程环境下的测试:在 main 方法中,我们创建了两个线程来并发调用 increment() 方法,以模拟多线程环境下的计数器操作。最后输出的结果应该是 2000,因为每个线程都对 count 进行了 1000 次递增操作。
上一篇:java string 转对象
下一篇:java math.random
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站