c++ - 我不小心没有使用 std::ref - 结果代码做了什么?

标签 c++ multithreading c++11

我正在处理我的代码突然分配大量内存,并试图找到问题的根源。有问题的代码非常简单,但我注意到在使用此函数创建的线程中:

void ParallelExpandBucket(openData d, const std::unordered_set<uint64_t> &states, int myThread, int totalThreads)

我正在创建没有 std::ref 的线程:

threads.push_back(new std::thread(ParallelExpandBucket, d, states, x, numThreads));

结果这里实际发生了什么?

我的猜测是我的数据被复制到线程构造函数中,然后从那里将引用传递给 ParallelExpandBucket。所以,这可以解释内存爆炸。

这是正确的,还是有其他问题?

最佳答案

你是对的。对 ExpandBucket 的调用获取对 states 拷贝的引用,该拷贝与 std::thread 实例存在的时间一样长。参数按值获取,因此这意味着复制。

在许多情况下,在 c++11 之前您曾经需要 std::ref,现在您不再需要了,这要归功于完美的转发。例如,在对 std::make_shared 的调用中。然而,在这种情况下(如在 std::bind 中),自动使用引用将是一个巨大的问题,因为如果不能保证 states 它会崩溃只要线程存在,它就会存在,如果它所引用的对象不复存在,线程就会不高兴。

关于c++ - 我不小心没有使用 std::ref - 结果代码做了什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32492949/

相关文章:

c++ - 如何使用 localtime() 获取 Arm ASM 中的当前时间?

c++ - 为什么 __builtin_prefetch 在这里没有任何作用?

c++ - 在 Boost.Spirit 中,为什么 vector 需要融合包装器(包装在结构中),而不是变体?

java - 如何让线程等待 JFrame 在 Java 中关闭?

java - 方法超时

c++ - 存在用户定义的析构函数时如何禁用隐式定义的复制构造函数生成

c++ - 即使在使用命名空间指令后也没有歧义引用错误

c++ - 如何在连接组件标记中使用不相交集?

c# - 多线程应用程序中的 RichTextBox 控件

c++ - 比较键和值 std::maps