c++ - 是否可以在信号处理程序中设置 promise ?

标签 c++ c++11 promise signal-handling

我正在寻找一种方法来停止每 2 秒执行一次任务的线程。我决定尝试使用 std::promise/future 以便线程可以在设置 Promise 时立即退出。

#include <future>
#include <iostream>
#include <chrono>
#include <csignal>

std::promise<void> stop;

int main() {

    std::signal(SIGINT, [] (int)  { stop.set_value(); } );

    auto future = stop.get_future();

    while (future.wait_for(std::chrono::seconds(1)) != std::future_status::ready) {
            std::cout << "I'm still there" << std::endl;
    }
}

实际上这不起作用并且会这样崩溃:

$ ./a.out I'm still there ^Cterminate called after throwing an instance of 'std::system_error'
what(): Unknown error -1 Abandon (core dumped)

好吧,人们应该注意他在处理程序上下文中所做的事情,但我必须说我没有预料到会发生这种崩溃;而且我真的不太明白... 你有什么想法吗?

最佳答案

我相信您在这里遇到的是由于在信号处理程序中调用标准库函数(不在信号安全函数列表中)而导致的未定义行为。

信号处理函数(用户定义的)的限制非常广泛,为 documented here .

另一件需要注意的事情是,信号处理程序是否引用任何具有静态或线程本地(C++11 起)存储持续时间的对象,该存储持续时间不是 std::atomic(C 起++11)或 volatile std::sig_atomic_t

正如 @BasileStarynkevitch 指出的那样,如果您使用的是 Linux,请确保仅 async-signal-safe从信号处理程序调用函数。

关于c++ - 是否可以在信号处理程序中设置 promise ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53015313/

相关文章:

c++ - 如何跳过基于范围的 for 循环中基于 'index' 的元素?

C++ 窗口时间

c++ - 为什么这会拒绝枚举?

c++ - 用户定义的文字定义

c++ - 修改 Makefile 以支持 c++11

c++ - 从模板中使用的结构类型中查找类型(可能是底层的)

c++ - 如何在 CMake 中设置编译标志?

node.js - 如何从 Promise Sequelize 返回值

javascript - PWA cache.addAll 在 ASP.NET 项目中不起作用

javascript - 使用 Bluebird 链接多个请求