我正在寻找一种方法来停止每 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 我还在那里
^Cterminate 在抛出“std::system_error”实例后调用
What(): 未知错误 -1 放弃
(核心已转储)
好的,一个人应该注意他在处理程序上下文中所做的事情,但我必须说我没有预料到会发生这种崩溃;而且我真的不太明白...
你有什么主意吗?
我相信您在这里遇到的是由于在信号处理程序中调用标准库函数(不在信号安全函数列表中)而导致的未定义行为。
信号处理函数(用户定义的)的限制非常广泛,记录在这里 https://en.cppreference.com/w/cpp/utility/program/signal.
另一件需要注意的事情是信号处理程序是否引用任何具有静态或线程本地(C++11 起)存储持续时间的对象std::atomic
(自 C++11 起)或volatile std::sig_atomic_t
.
正如 @BasileStarynkevitch 指出的那样,如果您使用的是 Linux,请确保仅异步信号安全 http://man7.org/linux/man-pages/man7/signal-safety.7.html从信号处理程序调用函数。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)