奇怪的Task:Task启动Action后 再次创建会失效 !

7 篇文章 0 订阅

自从有了task以后很少再启动线程Thread了。贴下代码:

比如以前要写成这样:

public void StartMonitor()
{
      t = new Thread(ParseReceiveData);//创建了线程还未开启
      t.IsBackground = true;
      t.Start();  
      isStarted = true;
 }
private void ParseReceiveData() {       
     int len = 112;
     while (isStarted){......}
}

现在只要写成这样就好了。

//方式1
Task.Factory.StartNew(ParseReceiveData);
//方式2
Task.Run(()=>ParseReceiveData());

用了很久了,今天碰着问题了。当点击停止以后,再次点击start时,代码不能再次执行ParseReceiveData方法了。

天哪,这难道是bug!!不过用了这么久没有把task,开了,在开过,确实也是第一次这么用结果就触雷了。

尤其是刚开始代码还是这样:parseTask = Task.Factory.StartNew(ParseReceiveData); 那基本上就2次就会有一次

不执行方法。结果一查才知道,Task 就是这样的。以后要想重复执行方法,请使用Timer。

以后记住了! Task 更多使用场合:搭配 await 吧。别哪哪都用!

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
`std::task::Context` 是 Rust 的异步编程库 `async-std` 和 `tokio` 中常用的类型,用于传递异步任务执行的上下文信息。它包含了当前任务的调度器、Waker、时间信息等。要使用 `Context`,需要先创建一个 `Waker` 对象,它任务可以继续执行时被唤醒。 下面是一个示例代码,展示了如何在 `async-std` 中使用 `Context`: ```rust use async_std::task::{Context, Poll}; use async_std::task; use std::future::Future; use std::pin::Pin; async fn my_task() { println!("Start task"); task::sleep(std::time::Duration::from_secs(1)).await; println!("Task completed"); } struct MyFuture {} impl Future for MyFuture { type Output = (); fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> { // 唤醒任务,使它可以执行 cx.waker().wake_by_ref(); Poll::Ready(()) } } fn main() { // 创建异步任务 let my_task = my_task(); // 执行异步任务 task::spawn(async move { // 等待异步任务完成 my_task.await; println!("My task is done"); // 创建 MyFuture 对象并执行它 let my_future = MyFuture {}; let mut my_future_pin = Pin::new(&mut my_future); my_future_pin.poll(&mut Context::from_waker(task::noop_waker_ref())).await; println!("MyFuture is done"); }); // 等待异步任务执行完成 task::block_on(async {}); } ``` 在上面的代码中,我们首先创建了一个异步任务 `my_task`,然后使用 `task::spawn` 执行它。在任务执行完成后,我们创建了一个 `MyFuture` 对象,并使用 `Context` 执行它。注意到 `poll` 方法中的 `cx.waker().wake_by_ref()`,它唤醒任务,使得它可以继续执行。 需要注意的是,`Context` 的创建需要传递一个 `Waker` 对象。在示例代码中,我们使用了 `task::noop_waker_ref()`,它是一个空的 `Waker` 对象,可以在不需要唤醒任务的情况下创建 `Context`。如果需要唤醒任务,可以自定义一个 `Waker` 对象并传递给 `Context`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值