众所周知,STL容器不是线程安全的。对于vector,即使写方(生产者)是单线程写入,但是并发读的时候,由于潜在的内存重新申请和对象复制问题,会导致读方(消费者)的迭代器失效。实际表现也就是招致了core dump。另外一种情况,如果是多个写方,并发的push_back(),也会导致core dump。
解法一:
加锁是一种解决方案,但是加std::mutex互斥锁确实性能较差。对于多读少写的场景可以用读写锁(也叫共享独占锁),来缓解。C++17引入了std::shared_mutex 。更多锁的种类可以阅读下面这篇文章,但是本文的目的自然不是自我重复再次介绍一次锁的使用,请继续阅读解法二!
解法二:
更多的时候,其实可以通过固定vector的大小,避免动态扩容(无push_back)来做到lock-free!
即在开始并发读写之前(比如初始化)的时候,给vector设置好大小。

STL容器并非线程安全,多线程读写可能导致迭代器失效或core dump。解决方案包括:1) 使用读写锁或固定大小的vector避免动态扩容;2) 利用resize预创建对象并使用下标访问;3) 对于关联容器,如果能预知所有key,可预先插入避免并发插入冲突;否则,仍需考虑加锁或使用并发控制策略。
https://blog.csdn.net/guodongxiaren/article/details/120799601
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



