在Java中,悲观锁的实现方式有两种:
示例代码:
public class LockExample {
private int count = 0;
public synchronized void increment() {
count++;
}
}
示例代码:
import java.util.concurrent.locks.ReentrantLock;
public class LockExample {
private int count = 0;
private ReentrantLock lock = new ReentrantLock();
public void increment() {
lock.lock();
try {
count++;
} finally {
lock.unlock();
}
}
}
这两种方式都是悲观锁的实现方式,因为它们都假设会出现并发冲突,因此在访问共享资源之前先获取锁,并阻塞其他线程的访问。与之相反,乐观锁则是假设不会出现并发冲突,直接进行操作,并在提交时检查是否有其他线程修改了数据。