如何在jthread中传递带有参数和stop_condition的函数
How to pass a function with arguments and stop_condition in jthread?
我正试图做一些类似的事情
#include <iostream>
#include <thread>
#include <chrono>
void doWork(char a, std::stop_token st = {}) {
while (!st.stop_requested()) {
std::cout << a << 'n';
}
}
int main() {
std::jthread t1{doWork, 'A'}, // error
t2{doWork, 'B'}; // error
std::this_thread::sleep_for(std::chrono::milliseconds(50));
}
但它不会在带有-std=c++2a
:的gcc主干上编译
/opt/compiler-explorer/gcc-trunk-20200219/include/c++/10.0.1/thread:537:20: error: static assertion failed: std::thread arguments must be invocable after conversion to rvalues
537 | static_assert(is_invocable_v<decay_t<_Callable>,
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
538 | decay_t<_Args>...>,
| ~~~~~~~~~~~~~~~~~~
有可能做这样的事情吗?
我认为这应该是可能的,因为我在lambda(这里(中看到了一个类似的例子:
//...
std::jthread t([&ready, &readyMutex, &readyCV] (std::stop_token st) {
while (!stoken.stop_requested()) {
//...
}
});
您的实现几乎是正确的。可调用的约束是它接受std::stop_token
作为第一个参数。因此,切换doWork
声明中的顺序将对其进行排序。
void doWork(std::stop_token st, char a) {
while (!st.stop_requested()) {
std::cout << a << 'n';
}
}
令牌来自库实现,所以它的构造无论如何都不会让您担心。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用