1. Konzept
Wiedereintretende Lese-/Schreibsperre behält intern eine ReadLock- und eine WriteLock-Sperre bei Gleichzeitiges Schreiben? Die hohen 16 Bits des Status (int) werden hier verwendet, um den Lesestatus darzustellen, die niedrigen 16 Bits stellen das Schreiben dar, die hohen 16 Bits stellen die Anzahl der Threads dar, die die Lesesperre erhalten, und die niedrigen 16 Bit stellen die Wiedereintrittszahl der Schreibsperre dar.
2. Prinzip
wird mithilfe der WarteschlangeCAS+AQS implementiert. Es unterstützt faire Sperren und unfaire Sperren, und die Implementierung der beiden ist ähnlich
3, Beispiele
public class ReentrantDemo implements Runnable { Lock lock = new ReentrantLock(); @Override public void run() { set(); } public void set() { try { lock.lock(); System.out.println("set 方法"); get(); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock();// 必须在finally中释放 } } public void get() { try { lock.lock(); System.out.println("get 方法"); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock(); } } public static void main(String[] args) { ReentrantDemo reentrantDemo = new ReentrantDemo(); new Thread(reentrantDemo).start(); } }
Das obige ist der detaillierte Inhalt vonJava-Testbeispiel zur Analyse der Wiedereintrittseigenschaften von ReentrantLock. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!