Heim  >  Artikel  >  Java  >  Java-Testbeispiel zur Analyse der Wiedereintrittseigenschaften von ReentrantLock

Java-Testbeispiel zur Analyse der Wiedereintrittseigenschaften von ReentrantLock

WBOY
WBOYnach vorne
2023-05-09 18:07:08719Durchsuche

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 Warteschlange

CAS+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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen