我有一个如下的代码(简化代码):
for( int i = 0; i < input.rows; i++ )
{
if(IsGoodMatch(input[I])
{
Newvalues newValues;
newValues.x1=input.x1;
newValues.x2=input.x1*2;
output.push_back( newValues);
}
}
这段代码很好用,但是如果我想使用omp parallel使其并行,则在output.push_back上会出现错误,似乎在 vector 调整大小期间,内存已损坏。
有什么问题,我该如何解决?
如何确保只有一个线程可以随时将一个新项目插入vector?
最佳答案
简单的答案是std::vector::push_back
不是线程安全的。
为了安全地并行执行此操作,您需要进行同步,以确保不会同时从多个线程中调用push_back
。
通过使用std::mutex
可以轻松实现C++ 11中的同步。