C++ 多线程 同时读取同一个vector 线程安全 吗

Posted 软件工程小施同学

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++ 多线程 同时读取同一个vector 线程安全 吗相关的知识,希望对你有一定的参考价值。

一.问题概述

两个线程,不加锁的情况下,

  • 一个线程读,一个线程写;
  • 或者两个线程同时写,

会导致进程崩溃。

如果两个线程同时读,不加锁的情况也不会出现问题。

二.示例代码

#include <boost/thread.hpp>
#include <vector>

using namespace std;
using namespace boost;
vector<int> g_vec;
void test()

    int a = 0;
    for(int i = 0; i< 100000000; ++ i)
    
        a = g_vec[0];
    


void test1()

    for(int i = 0; i< 100000000; ++ i)
    
        g_vec.push_back(1);
    

int main(int artc, char* argv[])

    g_vec.push_back(1);
    boost::thread thrd1(test);
    boost::thread thrd2(test1);
    thrd1.join();
    thrd2.join();
    return 0;

三.问题产生的原因解决问题的方法

vector是代替数组的简单容器,它不需要额外的代码能实现数组长度的动态扩展。
在test1方法中,连续的push_back会导致vector内部中的数组存储结构不停的delete和new。在test方法中,访问数组的第一个元素,有可能此时的内部结构已经被delete还没来得及new。
解决此种问题的思路一般是对vector的操作放在单独一个线程或者在使用此变量的作用域内加锁。
注:vector类型的g_vec即使声明为局部变量,存在栈上的也只有32个字节,参考vector的实现其内部是使用指针new在堆上的内存。

https://segmentfault.com/a/1190000019081900?utm_source=tag-newest

查了一下资料,原来vector每次push_back都会重新分配内存,导致goods 这个引用无效,所以goods.local_pic = local_pic赋值写入的时候就会写入到一个无效的地址,导致程序崩溃。



作者:coreki
链接:https://www.jianshu.com/p/e240421aa5f4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

以上是关于C++ 多线程 同时读取同一个vector 线程安全 吗的主要内容,如果未能解决你的问题,请参考以下文章

是否可以多线程同时执行非 void 函数? (C++)

如何读取锁定多线程 C++ 程序

C++ std::vector 可以同时处理来自多线程的 push_back 吗?

c++多线程中使用libcurl库的问题

在多线程 C++ 程序中使用 std::vector 时应用程序崩溃

在虚拟机上运行的 C++ 多线程文件读取问题