Objekt eingebautes Objekt

Objektsperre

Fiber Lock Objekt

Im Gegensatz zu Betriebssystemsperren werden Glasfasersperren mit reiner Logik implementiert, und die Last des Sperren und Entsperren ist sehr gering.

1 2 3 4
var l = new coroutine.Lock(); l.acquire(); ..... l.release();

Vererbung

%0 object object toString() toJSON() Lock Lock new Lock() acquire() release() count() object->Lock Condition Condition Lock->Condition Event Event Lock->Event Semaphore Semaphore Lock->Semaphore

Konstruktor

Lock

Konstruktor

1
new Lock();

Mitgliedsfunktion

acquire

Erhalt des Schlossbesitzes

1
Boolean Lock.acquire(Boolean blocking = true);

Parameter aufrufen:

  • blocking : Boolescher Wert, geben Sie an, ob gewartet werden soll, warten Sie, wenn true, der Standardwert ist true

Gibt das Ergebnis zurück:

  • Boolean , gibt zurück, ob die Sperre erfolgreich erfasst wurde. True zeigt eine erfolgreiche Erfassung an

Die Erwerbsmethode wird verwendet, um das Eigentum an der Sperre zu erwerben. Diese Methode gibt sofort true zurück, wenn sich die Sperre in einem erwerbbaren Zustand befindet.

Wenn die Sperre nicht verfügbar ist und die Blockierung wahr ist, geht die aktuelle Faser in den Ruhezustand. Wenn andere Fasern die Sperre aufheben, gibt diese Methode true zurück.

Wenn die Sperre nicht verfügbar ist und die Blockierung falsch ist, gibt die Methode false zurück.


release

Geben Sie das Eigentum an dem Schloss frei

1
Lock.release();

Diese Methode gibt den Besitz der Sperre frei. Wenn die aktuelle Glasfaser die Sperre nicht besitzt, gibt diese Methode einen Fehler aus.


count

Fragen Sie die Anzahl der aktuell wartenden Aufgaben ab

1
Integer Lock.count();

Gibt das Ergebnis zurück:

  • Integer , gibt die Anzahl der Aufgaben zurück

toString

Gibt eine Zeichenfolgendarstellung des Objekts zurück, normalerweise "[Native Object]". Objekte können gemäß ihren eigenen Merkmalen neu implementiert werden

1
String Lock.toString();

Gibt das Ergebnis zurück:

  • String , gibt eine String-Darstellung des Objekts zurück

toJSON

Gibt eine JSON-Darstellung des Objekts zurück, die normalerweise eine Sammlung lesbarer Eigenschaften zurückgibt, die vom Objekt definiert wurden

1
Value Lock.toJSON(String key = "");

Parameter aufrufen:

  • key : String, unbenutzt

Gibt das Ergebnis zurück:

  • Value , gibt einen Wert zurück, der einen serialisierbaren JSON enthält