使用 pthread_cancel 取消线程:好习惯还是坏习惯

2024-10-21 09:14:00
admin
原创
343
摘要:问题描述:我在 Linux(CentOS 5.3)上有一个 C++ 程序,它生成多个线程,这些线程处于无限循环中以执行作业并休眠几分钟。现在,我必须取消正在运行的线程,以防出现新的配置通知并重新启动一组新线程,为此我使用了 pthread_cancel。我观察到,即使收到取消指示后线程也不会停止,甚至一些休眠...

问题描述:

我在 Linux(CentOS 5.3)上有一个 C++ 程序,它生成多个线程,这些线程处于无限循环中以执行作业并休眠几分钟。现在,我必须取消正在运行的线程,以防出现新的配置通知并重新启动一组新线程,为此我使用了 pthread_cancel。我观察到,即使收到取消指示后线程也不会停止,甚至一些休眠线程在休眠完成后也会启动。

由于这种行为不是我们所期望的,在上述场景中使用 pthread_cancel 引发了人们对其是好是坏的疑问。

请评论上述场景中 pthread_cancel 的使用情况。


解决方案 1:

一般来说,取消线程并不是一个好主意。只要有可能,最好有一个共享标志,供线程用来跳出循环。这样,你就可以让线程在实际退出之前执行它们可能需要做的任何清理工作。

关于线程实际上没有取消的问题,POSIX 规范确定了一组取消点 ( man 7 pthreads )。线程只能在这些点被取消。如果您的无限循环不包含取消点,您可以通过调用来添加一个pthread_testcancel。如果pthread_cancel已被调用,那么它将在此时执行。

解决方案 2:

如果您正在编写异常安全的 C++ 代码(请参阅http://www.boost.org/community/exception_safety.html),那么您的代码自然就可以取消线程了。glibs在线程取消时抛出 C++ 异常,以便您的析构函数可以进行适当的清理。

解决方案 3:

您可以执行与以下代码等效的操作。

#include <pthread.h>
#include <cxxabi.h>
#include <unistd.h>
...
void *Control(void* pparam)
{
    try
    {
        // do your work here, maybe long loop
    }   
    catch (abi::__forced_unwind&)
    {  // handle pthread_cancel stack unwinding exception
        throw;
    }
    catch (exception &ex) 
    {
        throw ex;
    }
}

int main()
{
    pthread_t tid;
    int rtn;
    rtn = pthread_create( &tid, NULL, Control, NULL );

    usleep(500);
    // some other work here

    rtn = pthtead_cancel( tid );
}

解决方案 4:

我会使用 boost::asio。

类似于:

struct Wait {
  Wait() : timer_(io_service_), run_(true) {}

  boost::asio::io_service io_service_;
  mutable boost::asio::deadline_timer timer_;
  bool run_;
};

void Wait::doWwork() {
  while (run) {
    boost::system::error_code ec;
    timer_.wait(ec);
    io_service_.run();
    if (ec) {
      if (ec == boost::asio::error::operation_aborted) {
        // cleanup
      } else {
        // Something else, possibly nasty, happened
      }
    }
  }
}

void Wait::halt() {
  run_ = false;
  timer_.cancel();
}

一旦你理解了它,你就会发现 asio 是一个非常棒的工具。

相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1325  
  IPD(Integrated Product Development)流程作为一种先进的产品开发管理模式,在众多企业中得到了广泛应用。它涵盖了从产品概念产生到产品退市的整个生命周期,通过整合跨部门团队、优化流程等方式,显著提升产品开发的效率和质量,进而为项目的成功奠定坚实基础。深入探究IPD流程的五个阶段与项目成功之间...
IPD流程分为几个阶段   4  
  华为作为全球知名的科技企业,其成功背后的管理体系备受关注。IPD(集成产品开发)流程作为华为核心的产品开发管理模式,其中的创新管理与实践更是蕴含着丰富的经验和深刻的智慧,对众多企业具有重要的借鉴意义。IPD流程的核心架构IPD流程旨在打破部门墙,实现跨部门的高效协作,将产品开发视为一个整体的流程。它涵盖了从市场需求分析...
华为IPD是什么   3  
  IPD(Integrated Product Development)研发管理体系作为一种先进的产品开发模式,在众多企业的发展历程中发挥了至关重要的作用。它不仅仅是一套流程,更是一种理念,一种能够全方位提升企业竞争力,推动企业持续发展的有效工具。深入探究IPD研发管理体系如何助力企业持续发展,对于众多渴望在市场中立足并...
IPD管理流程   3  
  IPD(Integrated Product Development)流程管理旨在通过整合产品开发流程、团队和资源,实现产品的快速、高质量交付。在这一过程中,有效降低成本是企业提升竞争力的关键。通过优化IPD流程管理中的各个环节,可以在不牺牲产品质量和性能的前提下,实现成本的显著降低,为企业创造更大的价值。优化产品规划...
IPD流程分为几个阶段   4  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用