thread::hardware_concurrency() 作为模板参数
thread::hardware_concurrency() as template parameter
我有一个模板类,其中包含一个无符号的 int 参数,用于表示线程数。我想使用它为线程创建一个静态数组。
我也不能使用std::thread::hardware_concurrency()
作为默认值,
template <typename T, size_t num_threads = std::thread::hardware_concurrency()>
class Some_class{
T values[num_threads];
...
}
也没有把它作为参数给我的类。
template <typename T, size_t num_threads>
class Some_class{
T values[num_threads];
...
}
Some_class<int,std::thread::hardware_concurrency()> instance;
问题是std::thread::hardware_concurrency()
的返回值不是常量。
编译器说:
error: call to non-constexpr function ‘static unsigned int std::thread::hardware_concurrency()’
note: in template argument for type ‘long unsigned int’
是否有另一种静态方法可以获取模板的可用线程数?
有没有另一种静态方法来获取模板的可用线程数?
答案是否定的,因为 std::thread::hardware_concurrency(( 不是constexpr函数(并发线程的数量可能因程序工作的系统而异,所以这是绝对合乎逻辑的,对吧?(,但num_threads
必须使用编译时常量进行初始化。
您可能会处理一些解决方法,例如使用std::vector
而不是数组:
template <typename T>
class SomeClass {
public:
SomeClass()
: values(std::thread::hardware_concurrency())
{}
private:
std::vector<T> values;
};
没有静态方法来获取系统上逻辑 CPU 的数量。这个数字可以很容易地在编译和执行之间改变,例如,如果二进制文件在不同的系统上执行。
您可以获取从构建系统编译代码的系统逻辑 CPU 的数量,例如使用 CMake 的 ProcessorCount 并将其放入定义中。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用