Java 线程锁用于防止并发冲突,确保一个线程独占访问资源。获取锁的方法有:synchronized 关键字,用于方法或代码块,确保线程执行代码时持有锁。java.util.concurrent 包中的显式锁对象(如 ReentrantLock、ReadWriteLock),允许显式获取和释放锁,提供更精细的控制。
Java 线程锁如何工作
锁的目的是什么?
- 在多线程环境中,锁用于确保资源仅供一个线程独占访问,从而防止并发冲突。
在 Java 中如何获取锁?
要获取锁,可以使用 synchronized 关键字或 java.util.concurrent 包中的显式锁对象。
synchronized 关键字
-
synchronized关键字可以应用于方法或代码块,它确保在执行该代码时,锁将被线程持有。 -
示例:
public class MyClass { private int count; public synchronized void increment() { count++; } }
显式锁对象
-
java.util.concurrent包中的锁对象,如ReentrantLock和ReadWriteLock,可以用来显式获取和释放锁。 -
示例:
i
mport java.util.concurrent.locks.ReentrantLock;
public class MyClass {
private int count;
private ReentrantLock lock = new ReentrantLock();
public void increment() {
lock.lock();
try {
count++;
} finally {
lock.unlock();
}
}
}
锁的类型
互斥锁:此锁一次只能被一个线程持有,例如 synchronized 关键字和 ReentrantLock。
读写锁:此锁允许多个线程同时读取共享资源,但只有一个线程可以写入,例如 ReadWriteLock。
公平锁:根据线程请求锁的顺序授予锁,例如 ReentrantLock(true)。
非公平锁:不会尊重线程请求锁的顺序,它可能导致某些线程饥饿,例如 ReentrantLock(false)。
何时使用显式锁对象
显式锁对象通常用于以下情况:
- 需要更精细的锁控制(如重入锁或读写锁)。
- 需要在不同的类或对象之间共享锁。

mport java.util.concurrent.locks.ReentrantLock;
public class MyClass {
private int count;
private ReentrantLock lock = new ReentrantLock();
public void increment() {
lock.lock();
try {
count++;
} finally {
lock.unlock();
}
}
}






