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