C:矢量“腐败”的第一个要素

C:矢量“腐败”的第一个要素,第1张

概述我有一个包含向量的类(foo). 如果我尝试迭代向量中的元素,如下所示: for(vector<random>::iterator it = foo.getVector().begin(); it != foo.getVector().end(); ++it) { cout << (*it) << endl;} 第一个元素总是被破坏并返回垃圾数据. 但是,如果做的事情如下: 我有一个包含向量的类(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在整个循环中是有效的.

总结

以上是内存溢出为你收集整理的C:矢量“腐败”的第一个要素全部内容,希望文章能够帮你解决C:矢量“腐败”的第一个要素所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/langs/1222125.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存