C:矢量“腐败”的第一个要素
发布时间:2020-12-16 10:41:54 所属栏目:百科 来源:网络整理
导读:我有一个包含向量的类(foo). 如果我尝试迭代向量中的元素,如下所示: for(vectorrandom::iterator it = foo.getVector().begin(); it != foo.getVector().end(); ++it) { cout (*it) endl;} 第一个元素总是被破坏并返回垃圾数据. 但是,如果做的事情如下: ve
我有一个包含向量的类(foo).
如果我尝试迭代向量中的元素,如下所示: for(vector<random>::iterator it = foo.getVector().begin(); it != foo.getVector().end(); ++it) { cout << (*it) << endl; } 第一个元素总是被破坏并返回垃圾数据. 但是,如果做的事情如下: vector<random> v = foo.getVector(); for(vector<random>::iterator it = v.begin(); it != v.end(); ++it) { cout << (*it) << endl; } 一切似乎都很好.有一个我不知道的“陷阱”吗? 我也尝试过做cout<< foo.getVector()[0]<< ENDL;循环之外,但似乎工作正常. 谢谢. 编辑: 这是我的头文件: #ifndef HITS #define HITS #include <vector> #include "wrappers.h" class Hits { public: Hits(); std::vector<word_idx_value> getVector() {return speech_hits;} const std::vector<word_idx_value> getVector() const {return speech_hits;} void add(const word_idx_value&); Hits &operator+=(const Hits&); private: std::vector<word_idx_value> speech_hits; }; #endif 解决方法for(vector<random>::iterator it = foo.getVector().begin(); 当你执行foo.getVector()时会返回临时向量,并且它会被破坏;在foo.getVector()之后遇到.begin();因此迭代器在循环内变得无效. 如果存储foo.getVector()的值;在向量v(v = foo.getVector();)然后使用向量v,它工作正常.这是因为向量v在整个循环中是有效的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |