pub struct TaskLocalFuture<T, F>where
T: 'static,{ /* 私有字段 */ }展开描述
在 future F 执行期间为其设置任务本地值 T 的 future。
任务本地的值必须为 'static,并将在 future 完成时被 drop。
由函数 LocalKey::scope 创建。
§示例
tokio::task_local! {
static NUMBER: u32;
}
NUMBER.scope(1, async move {
println!("task local value: {}", NUMBER.get());
}).await;实现§
源代码§impl<T, F> TaskLocalFuture<T, F>where
T: 'static,
impl<T, F> TaskLocalFuture<T, F>where
T: 'static,
源代码pub fn take_value(self: Pin<&mut Self>) -> Option<T>
pub fn take_value(self: Pin<&mut Self>) -> Option<T>
返回此 TaskLocalFuture 存储在任务本地中的值。
函数返回:
Some(T)if the task local value exists.Noneif the task local value has already been taken.
请注意,即使 future 尚未完成,此函数也会尝试获取任务本地值。在这种情况下,在调用 take_value 之后,该值将不再可通过任务本地获得。
§示例
tokio::task_local! {
static KEY: u32;
}
let fut = KEY.scope(42, async {
// Do some async work
});
let mut pinned = Box::pin(fut);
// Complete the TaskLocalFuture
let _ = pinned.as_mut().await;
// And here, we can take task local value
let value = pinned.as_mut().take_value();
assert_eq!(value, Some(42));trait 实现§
源代码§impl<T, F> Debug for TaskLocalFuture<T, F>where
T: Debug + 'static,
impl<T, F> Debug for TaskLocalFuture<T, F>where
T: Debug + 'static,
源代码§impl<T: 'static, F: Future> Future for TaskLocalFuture<T, F>
impl<T: 'static, F: Future> Future for TaskLocalFuture<T, F>
impl<'__pin, T, F> Unpin for TaskLocalFuture<T, F>where
PinnedFieldsOf<__Origin<'__pin, T, F>>: Unpin,
T: 'static,
自动 trait 实现§
impl<T, F> Freeze for TaskLocalFuture<T, F>
impl<T, F> RefUnwindSafe for TaskLocalFuture<T, F>where
T: RefUnwindSafe,
F: RefUnwindSafe,
impl<T, F> Send for TaskLocalFuture<T, F>
impl<T, F> Sync for TaskLocalFuture<T, F>
impl<T, F> !UnsafeUnpin for TaskLocalFuture<T, F>
impl<T, F> UnwindSafe for TaskLocalFuture<T, F>where
T: UnwindSafe,
F: UnwindSafe,
blanket 实现§
源代码§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
源代码§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. 更多信息
源代码§impl<F> IntoFuture for Fwhere
F: Future,
impl<F> IntoFuture for Fwhere
F: Future,
源代码§type IntoFuture = F
type IntoFuture = F
我们将要把此值转变成哪种 future?
源代码§fn into_future(self) -> <F as IntoFuture>::IntoFuture
fn into_future(self) -> <F as IntoFuture>::IntoFuture
Creates a future from a value. 更多信息