Struct sero::LockWaiter

source ·
pub struct LockWaiter<K>where
    K: Hash + Eq + Clone + Send + Sync + 'static,
{ /* private fields */ }
Expand description

A LockWaiter represents a waiter waiting to access a lock on a key.

The LockWaiter can be consumed synchronously using LockWaiter::wait (which will park the current thread until it is available) or asynchronously through .await.

Example:

let waiter = store.lock("test");
let guard = waiter.wait();
// OR
let guard = waiter.await;

Implementations§

Wait for the lock to be available and acquire a guard, when the guard is dropped the lock is released and can be acquired again Note: Calling this method will park the current thread, this may cause issues, especially in an asynchronous context, and cause a deadlock.

Example
let waiter = store.lock("test");
let guard = waiter.wait();

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
The type of value produced on completion.
Attempt to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The output that the future will produce on completion.
Which kind of future are we turning this into?
Creates a future from a value. Read more
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.