【问题标题】:How to implement a multi-threaded asynchronous operation?如何实现多线程异步操作?
【发布时间】:2012-09-05 20:05:49
【问题描述】:

这是我目前的方法的样子:

// Somewhere in a UI class
// Called when a button called "Start" clicked
MyWindow::OnStartClicked(Event &sender)
{
  _thread = new boost::thread(boost::bind(&MyWindow::WorkToDo, this));
}

MyWindow::WorkToDo()
{
  for(int i = 1; i < 10000000; i++)
  {
    int percentage = (int)((float)i / 100000000.f);
    _progressBar->SetValue(percentage);
    _statusText->SetText("Working... %d%%", percentage);
    printf("Pretend to do something useful...\n");
  }
}

// Called on every frame
MyWindow::OnUpdate()
{
  if(_thread != 0 && _thread->timed_join(boost::posix_time::seconds(0))
  {
    _progressBar->SetValue(100);
    _statusText->SetText("Completed!");
    delete _thread;
    _thread = 0;
  }
}

但我担心这很不安全,因为我在程序执行结束时不断收到未处理的异常。

我基本上想将繁重的任务分离到另一个线程中而不阻塞 GUI 部分。

【问题讨论】:

  • 您提供的这段代码应该可以工作。你能以某种方式指定“未处理的异常”吗?
  • 我正在使用 SFML2 进行渲染,但异常来自 SFML 的 MutexImpl.cpp。如果详细信息来自另一个库,恐怕对于这个问题来说太具体了。

标签: c++ multithreading boost-thread


【解决方案1】:

有很多方法可以做到这一点,很难确定。在 Windows 中,您通常会根据 GUI 操作启动线程,结果和/或进度通过消息泵循环发送回 GUI。您将声明或注册自定义窗口消息,并让工作线程的各种报告位置将它们发布到主窗口句柄或子窗口句柄设置以监控异步进度。

有很多很多方法可以做到这一点。以上只是一种描述,但对于中等任务,我发现它通常可以解决问题。既然如此,您就可以正确使用此处显示的代码。您正在直接设置并绕过消息循环(不是真的,但就您需要关心的而言),所以这应该可以工作。

【讨论】:

    【解决方案2】:

    如果你可以使用 Boost 或 C++11,试试 boost/std::future 和 async

    【讨论】:

      猜你喜欢
      • 2022-12-21
      • 1970-01-01
      • 2014-01-04
      • 1970-01-01
      • 1970-01-01
      • 2018-05-07
      • 2011-02-01
      • 1970-01-01
      • 2011-05-15
      相关资源
      最近更新 更多