Struct tokio_util::task::LocalPoolHandle
source · [−]pub struct LocalPoolHandle { /* private fields */ }This is supported on crate feature
rt only.Expand description
A handle to a local pool, used for spawning !Send tasks.
Implementations
sourceimpl LocalPoolHandle
impl LocalPoolHandle
sourcepub fn new(pool_size: usize) -> LocalPoolHandle
pub fn new(pool_size: usize) -> LocalPoolHandle
Create a new pool of threads to handle !Send tasks. Spawn tasks onto this
pool via LocalPoolHandle::spawn_pinned.
Panics
Panics if the pool size is less than one.
sourcepub fn spawn_pinned<F, Fut>(&self, create_task: F) -> JoinHandle<Fut::Output> where
F: FnOnce() -> Fut,
F: Send + 'static,
Fut: Future + 'static,
Fut::Output: Send + 'static,
pub fn spawn_pinned<F, Fut>(&self, create_task: F) -> JoinHandle<Fut::Output> where
F: FnOnce() -> Fut,
F: Send + 'static,
Fut: Future + 'static,
Fut::Output: Send + 'static,
Spawn a task onto a worker thread and pin it there so it can’t be moved
off of the thread. Note that the future is not Send, but the
FnOnce which creates it is.
Examples
use std::rc::Rc;
use tokio_util::task::LocalPoolHandle;
#[tokio::main]
async fn main() {
// Create the local pool
let pool = LocalPoolHandle::new(1);
// Spawn a !Send future onto the pool and await it
let output = pool
.spawn_pinned(|| {
// Rc is !Send + !Sync
let local_data = Rc::new("test");
// This future holds an Rc, so it is !Send
async move { local_data.to_string() }
})
.await
.unwrap();
assert_eq!(output, "test");
}Trait Implementations
sourceimpl Clone for LocalPoolHandle
impl Clone for LocalPoolHandle
sourcefn clone(&self) -> LocalPoolHandle
fn clone(&self) -> LocalPoolHandle
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
Auto Trait Implementations
impl !RefUnwindSafe for LocalPoolHandle
impl Send for LocalPoolHandle
impl Sync for LocalPoolHandle
impl Unpin for LocalPoolHandle
impl !UnwindSafe for LocalPoolHandle
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
🔬 This is a nightly-only experimental API. (
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more