Struct embassy_executor::SendSpawner
source · pub struct SendSpawner { /* private fields */ }
Expand description
在任意线程中,生成任务到执行器中的句柄
这个生成器可以被任意现场使用(它是 Send 的),但是它只能创建 Send 的任务。 这是因为生成器本质上是将任务 “发送” 给执行器的线程。
如果你线创建 non-Send 的任务,请使用 Spawner.
Handle to spawn tasks into an executor from any thread.
This Spawner can be used from any thread (it is Send), but it can only spawn Send tasks. The reason for this is spawning is effectively “sending” the tasks to the executor thread.
If you want to spawn non-Send tasks, use Spawner.
Implementations§
source§impl SendSpawner
impl SendSpawner
sourcepub async fn for_current_executor() -> Self
pub async fn for_current_executor() -> Self
从当前执行器中获取生成器
这个函数是 async
的,仅是为了访问当前异步上下文。它会立即返回,不会阻塞。
#异常 如果当前执行器不是的 Embassy 执行器就会发生异常。
Get a Spawner for the current executor.
This function is async
just to get access to the current async
context. It returns instantly, it does not block/yield.
Panics
Panics if the current executor is not an Embassy executor.
sourcepub fn spawn<S: Send>(&self, token: SpawnToken<S>) -> Result<(), SpawnError>
pub fn spawn<S: Send>(&self, token: SpawnToken<S>) -> Result<(), SpawnError>
创建一个任务到执行器中
你可以调用任务函数来获取token
(比如一个被#[embassy_executor::task]
标记的函数)
Spawn a task into an executor.
You obtain the token
by calling a task function (i.e. one marked with #[embassy_executor::task]
).
sourcepub fn must_spawn<S: Send>(&self, token: SpawnToken<S>)
pub fn must_spawn<S: Send>(&self, token: SpawnToken<S>)
Trait Implementations§
source§impl Clone for SendSpawner
impl Clone for SendSpawner
source§fn clone(&self) -> SendSpawner
fn clone(&self) -> SendSpawner
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more