C++迭代器iterator段错误segmentation fault (core dumped)

  调试数据层中的Storage类时出现segmentation fault (core dumped),最终将错误源头锁定在Storage类一个成员函数中的这段代码:

//"A","B&C"

//fault

for(auto x:m_meetingList){
    m<<"\""<<x.getSponsor()<<"\",\"";
    for(auto iter=x.getParticipator().begin();iter!=x.getParticipator().end();++iter){
        cout<<*iter;
        /*auto temIter=iter;
        if(++temIter!=x.getParticipator().end())
            cout<<"&";
        */
    }
    std::cout<<std::endl;
}

  错误之处:

auto iter=x.getParticipator().begin();iter!=x.getParticipator().end()

  解决方法,改成这样:

std::vector<std::string> participators=x.getParticipator();
for(auto iter=participators.begin();iter!=participators.end();++iter)

  全貌:

//"A","B&C"

//correct

for(auto x:m_meetingList){
    m<<"\""<<x.getSponsor()<<"\",\"";
    std::vector<std::string> participators=x.getParticipator();
    for(auto iter=participators.begin();iter!=participators.end();++iter){
        cout<<*iter;
        /*auto temIter=iter;
        if(++temIter!=participators.end())
            cout<<"&";
        */
    }
    std::cout<<std::endl;
}

错误原因:

auto iter=x.getParticipator().begin();iter!=x.getParticipator().end()

  x.getParticipator()返回时隐式调用了拷贝构造函数,两个x.getParticipator()就调用了两次拷贝构造函数,前后两个x.getParticipator()并不是同一vector对象,引起异常。

说明:

  m_meetingListStorage类的私有成员,存放Meeting类的对象。

private:
    std::list<Meeting> m_meetingList;

  Meeting类的部分私有成员:赞助者的名字,参与者的名单

privatestd::string m_sponsor;
    std::vector<std::string> m_participators;

  getparticipator()Meeting类的公有成员函数,复制m_participators,返回出来。

/**
* @brief get the participators of a meeting 
* @return return a string vector indicate participators
*/
std::vector<std::string>getparticipator(void) const;
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中的代码段是一个C++程序,其中出现了段错误Segmentation fault (core dumped))的问题。段错误通常是内存访问错误导致的,比如访问了未初始化的指针、越界访问数组等。在这段代码中,出现段错误的原因是在插入元素后,没有重新计算迭代器mid的值,导致mid失效。 为了解决这个问题,可以在每次插入元素后,重新计算mid的值。具体做法是在插入元素后,计算插入了几个元素(通过cnt变量记录),然后重新计算mid = vint.begin() + vint.size() / 2 + cnt。这样就可以保证mid的正确性。 另外,还需要注意在循环中对迭代器iter进行操作时,需要确保iter在循环内部有适当的递增操作,否则可能陷入死循环。在这段代码中,iter在插入元素后进行了iter++操作,但是缺少了iter += cnt的操作,这也是需要修复的地方。 修正后的代码如下: ```c++ #include <iostream> #include <vector> using namespace std; typedef vector<int> VECTORTYPE; void print(VECTORTYPE &vec); int main() { vector<int> vint{0, 1, 2, 3, 4, 5}; vector<int>::iterator iter = vint.begin(); vector<int>::iterator mid = vint.begin() + vint.size() / 2; int some_val = 2; cout << "mid element is: " << *mid << endl; int cnt = 0; while (iter != mid) { if (*iter == some_val) { iter = vint.insert(iter, 2 * some_val); iter += cnt; mid = vint.begin() + vint.size() / 2 + cnt; cnt++; } else { iter++; } } print(vint); return 0; } void print(VECTORTYPE &vec) { for (VECTORTYPE::iterator i = vec.begin(); i != vec.end(); i++) { cout << *i << " "; } cout << endl; } ``` 修正后的代码将会正确运行,并输出修改后的vector内容。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [c++ Segmentation fault (core dumped) 的一个实例](https://blog.csdn.net/digitalkee/article/details/107781648)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [segmentation fault (core dumped)](https://blog.csdn.net/sexyluna/article/details/123766687)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值