Struct ThreadPool

Source
pub struct ThreadPool { /* private fields */ }

Implementations§

Source§

impl ThreadPool

Source

pub fn new(size: usize) -> Self

Basic thread pool implementation.

Create a new ThreadPool with the given size.

Source

pub fn group_submit(&self, wg: &WaitGroup, f: impl FnOnce() + Send + 'static)

Source

pub fn submit<F>(&self, f: F)
where F: FnOnce() + Send + 'static,

Execute a job in the thread pool. This is a ‘fire and forget’ method.

Source

pub fn submit_with_result<F, T>(&self, f: F) -> WorkResult<T>
where F: FnOnce() -> T + Send + 'static, T: Send + 'static,

Execute a job in the thread pool and return a WorkResult that can be used to get the result of the job.

Source

pub fn num_workers(&self) -> usize

Source

pub fn is_alive(&self) -> bool

Trait Implementations§

Source§

impl Drop for ThreadPool

Drop implementation for ThreadPool. This will terminate all workers when the ThreadPool is dropped. We need to make sure that all workers are terminated before the ThreadPool is dropped.

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V