pub struct WorkQueue<T> { /* private fields */ }
Expand description
Multi-producer, multi-consumer async job queue with end conditions.
Keeps track of in-progress jobs and can indicate to workers that all work has been finished. Intended to be used for jobs that will spawn other jobs during processing, but stop once all jobs have finished.
§Example use
#![allow(non_snake_case)]
type DemoJob = (&'static str, usize);
/// Job processing function.
///
/// For a given job `(name, n)`, returns two jobs with `n = n - 1`, unless `n == 0`.
async fn process_job(job: DemoJob) -> Vec<DemoJob> {
tokio::time::sleep(Duration::from_millis(25)).await;
let (tag, n) = job;
if n == 0 {
Vec::new()
} else {
vec![(tag, n - 1), (tag, n - 1)]
}
}
/// Job-processing worker.
///
/// `id` is the worker ID for logging.
async fn worker(id: usize, q: Arc<WorkQueue<DemoJob>>) {
println!("worker {}: init", id);
while let Some(job) = q.next_job().await {
println!("worker {}: start job {:?}", id, job.inner());
for new_job in process_job(job.inner().clone()).await {
q.push_job(new_job);
}
println!("worker {}: finish job {:?}", id, job.inner());
}
println!("worker {}: shutting down", id);
}
const WORKER_COUNT: usize = 3;
let q = Arc::new(WorkQueue::default());
q.push_job(("A", 3));
let workers: FuturesUnordered<_> = (0..WORKER_COUNT).map(|id| worker(id, q.clone())).collect();
// Wait for all workers to finish.
workers.for_each(|_| async move {}).await;
Implementations§
Source§impl<T> WorkQueue<T>
impl<T> WorkQueue<T>
Sourcepub async fn next_job(self: &Arc<Self>) -> Option<JobHandle<T>>
pub async fn next_job(self: &Arc<Self>) -> Option<JobHandle<T>>
Pop a job from the queue.
If there is a job in the queue, returns the job and increases the internal in progress counter by one.
If there are still jobs in progress, but none queued, waits until either of these conditions changes, then retries.
If there are no jobs available and no jobs in progress, returns None
.
Trait Implementations§
Auto Trait Implementations§
impl<T> !Freeze for WorkQueue<T>
impl<T> RefUnwindSafe for WorkQueue<T>
impl<T> Send for WorkQueue<T>where
T: Send,
impl<T> Sync for WorkQueue<T>where
T: Send,
impl<T> Unpin for WorkQueue<T>where
T: Unpin,
impl<T> UnwindSafe for WorkQueue<T>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<From, To> FallibleInto<To> for Fromwhere
To: TryFrom<From>,
impl<From, To> FallibleInto<To> for Fromwhere
To: TryFrom<From>,
fn try_into_wrapped(self) -> Result<To, VMError>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out
indicating that a T
is niched.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Upcastable for T
impl<T> Upcastable for T
Source§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
Source§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref