c++ - vector 上的 push_back 调用导致的段错误(线程 linux)

标签 c++ linux multithreading segmentation-fault push-back

所以我想做的是编写一个程序来创建一系列子线程,这些子线程使用 pthread_create 方法获取参数并使用传入的参数进行更多操作等等。我试图传入的参数是一个名为 reduce_args_ 的 vector 参数。这是结构 ReduceVector 的 header 信息。

typedef vector<string> StringVector;

// a data structure to maintain info for the reduce task
struct ReduceArg
{
  ReduceArg (void);  // constructor
  ~ReduceArg (void); // destructor

  pthread_t tid;  // thread id of the reduce thread
  StringVector files_to_reduce; // set of files for reduce task
};

// more typedefs
typedef vector<ReduceArg *> ReduceVector;

现在当我在这里调用 push_back 时问题来了:

for(int i = 0; i < num_reduce_threads_ ; i++){
            reduce_args_.push_back(phold);
        int count = 0;
        for(ShuffleSet::iterator it = shuffle_set_.begin(); it!=shuffle_set_.end(); ++it){
            string line = *it;
            string space = " ";
            string file = line.substr(0, line.find(space)) + ".txt";

            if (count < num_reduce_threads_){
                cout << reduce_args_[i+1];
                (reduce_args_[i+1] -> files_to_reduce)[count] = file;
                            //(reduce_args_[i+1] -> files_to_reduce).push_back(file);
             }
             count++;
            //cout << ((reduce_args_.back())->files_to_reduce).back()<< endl;
    }
}

这两种 push_back 方法都会导致段错误。洗牌集只是一个集合,正在输出字符串。正如 .h 文件中所述,files_to_reduce 是一个字符串 vector 。所以我想做的是访问 files_to_reduce 和 push_back 一个字符串到它上面,但每次我都遇到段错误。 reduce_args_ obj 声明如下:

ReduceArg* plhold;
    reduce_args_.push_back(plhold);
    ((reduce_args_.back()) -> files_to_reduce).push_back("hello");
    for (int i = 0; i < this->num_reduce_threads_; ++i) {
      // create a placeholder reduce argument and store it in our vector
      (reduce_args_.push_back(plhold));
    }

感谢您的帮助!

最佳答案

这个:

ReduceArg* plhold;
reduce_args_.push_back(plhold);

除非您隐藏了一些重要的代码,否则您将推送一个未初始化的指针,因此下一行将导致困惑。

可能是这个意思?

ReduceArg* plhold(new ReduceArg);

..但我怀疑您没有正确考虑对象的生命周期和您将其地址存储在 vector 中的对象的所有权。

一般来说,除非您完全知道自己在做什么以及为什么,否则请避免使用指针。发布的代码不需要它们,我建议您只使用这样的代码:

typedef vector<ReduceArg> ReduceVector;

....
reduce_args_.push_back(ReduceArg());
reduce_args_.back().files_to_reduce.push_back("hello");
for (int i = 0; i < num_reduce_threads_; ++i) {
  // create a placeholder reduce argument and store it in our vector
  (reduce_args_.push_back(ReduceArg());
}

关于c++ - vector 上的 push_back 调用导致的段错误(线程 linux),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19502228/

相关文章:

c++ - cout << with char* 参数打印字符串,而不是指针值

c++ - 在线程函数中处理异常

java - 在mysql中插入记录导致线程数增加

c++ - 指向成员 : works in GCC but not in VS2015 的指针

c++ - Boost Asio serial_port - 需要 io 帮助

java - Z-Linux 上的 BlazeDS 支持

linux - 具有扩展 key 用法的证书仅适用于 Firefox

c++ - packaged_task 卡在 operator() 上

c++ - std::experimental::is_detected 的奇怪 MSVC 行为

python - 列表中的目录内容