Struct async_sema::Semaphore
source · pub struct Semaphore { /* private fields */ }
Expand description
A counter for limiting the number of concurrent operations.
Implementations§
source§impl Semaphore
impl Semaphore
sourcepub const fn new(n: usize) -> Semaphore
pub const fn new(n: usize) -> Semaphore
Creates a new semaphore with a limit of n
concurrent operations.
§Examples
use async_semaphore::Semaphore;
let s = Semaphore::new(5);
sourcepub fn try_acquire(&self) -> bool
pub fn try_acquire(&self) -> bool
Attempts to get a permit for a concurrent operation.
If the permit could not be acquired at this time, then None
is returned. Otherwise, a
guard is returned that releases the mutex when dropped.
§Examples
use async_sema::Semaphore;
let s = Semaphore::new(2);
s.try_acquire().unwrap();
s.try_acquire().unwrap();
assert!(s.try_acquire().is_none());
s.add_permits(1);
assert!(s.try_acquire().is_some());
sourcepub async fn acquire(&self)
pub async fn acquire(&self)
Waits for a permit for a concurrent operation.
Returns a guard that releases the permit when dropped.
§Examples
use async_sema::Semaphore;
let s = Semaphore::new(2);
s.acquire().await;
sourcepub fn add_permits(&mut self, n: usize)
pub fn add_permits(&mut self, n: usize)
Add permit for a concurrent operations
§Examples
use async_sema::Semaphore;
let s = Semaphore::new(0);
assert!(s.try_acquire().is_none());
s.add_permits(1);
assert!(s.try_acquire().is_some());
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for Semaphore
impl RefUnwindSafe for Semaphore
impl Send for Semaphore
impl Sync for Semaphore
impl Unpin for Semaphore
impl UnwindSafe for Semaphore
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more