Object built-in object

Object Lock

Fiber lock object

Unlike the lock of the operating system, the fiber lock is implemented by pure logic, and the load of locking and unlocking is very small

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

Inheritance

%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

Constructor

Lock

Constructor

1
new Lock();

Member function

acquire

Take ownership of the lock

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

Call parameters:

  • blocking : Boolean, specify whether to wait, wait if true, default is true

Return result:

  • Boolean , returns whether the lock was successfully acquired, true means successful acquisition

The acquire method is used to acquire the ownership of the lock. When the lock is in an acquireable state, this method returns true immediately.

When the lock is unavailable and blocking is true, the current fiber goes to sleep. When other fibers release the lock, this method returns true.

When the lock is not available and the blocking is false, the method returns false.


release

Release ownership of the lock

1
Lock.release();

This method will release the ownership of the lock. If the current fiber does not own the lock, this method will throw an error.


count

Query the current number of waiting tasks

1
Integer Lock.count();

Return result:

  • Integer , returns the number of tasks

toString

Returns the string representation of the object, generally returns "[Native Object]", the object can be reimplemented according to its own characteristics

1
String Lock.toString();

Return result:

  • String , returns a string representation of the object

toJSON

Returns the JSON format representation of the object, generally returns a collection of readable attributes defined by the object

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

Call parameters:

  • key : String, unused

Return result:

  • Value , returns a value containing JSON serializable