我现在已经使用下面的代码进行了相当多的测试,没有遇到任何问题,但是我刚刚意识到代码可能不是threadsafe,并导致竞态条件。
...
std::shared_ptr<T> ptr(new T(bar));
auto foo = [=] (tbb::blocked_range<int> r) {
std::shared_ptr<T> p(ptr); // <- Is this threadsafe?
// ... do stuff
};
tbb::parallel_for(tbb::blocked_range<int>(0,x), foo);
...我的问题是关于标记的行,因为我认为在共享指针的复制构造过程中,由于增加了引用计数,可能会发生竞态。
虽然我可以通过引用捕获指针并直接使用它来避免这种情况,但我仍然对解决方案感兴趣。
发布于 2011-12-21 04:26:57
不,如果编译时打开了多线程的选项,库应该使用原子操作或锁来计算共享指针的引用计数。正如您发布的代码一样,代码没有线程安全问题。
https://stackoverflow.com/questions/8581466
复制相似问题