将迭代器和向量传递给函数
Passing an iterator and vector to a function
我有一些函数
void print_elem(const std::vector<int>::iterator it, const std::vector<int> &vec) {/*.....*/}
如果我忽略了向量是对原始对象的引用,我会得到向量的副本。为什么迭代器的情况不一样?为什么迭代器不需要也是一个引用?
例如,如果我想遍历向量,打印每个元素,并希望在到达向量末尾时停止,除非我传递对向量的引用,否则迭代只会连续遍历第一个向量副本。但如果我通过一个引用,迭代就会通过原始向量对象。但是,为什么迭代器没有像没有引用的向量那样被复制呢?
迭代器为指针建模,它很可能是是一个,或者包含一个指向向量或其内容的指针。当您复制它时,副本实际上是一个不同的迭代器,但它存储相同的值,所以它仍然指向相同的东西,就像指针一样。
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- 如何使用向量的template_back函数
- 如何通过派生类函数更改基类中的向量
- 变量没有改变?通过向量的函数调用
- 一对向量构造函数:初始值设定项列表与显式构造
- 在c++中使用向量时,如何调用构造函数和析构函数
- std::sort()函数无法对向量的一部分进行排序
- 如何在C++向量中奇数元素前面加上值-1,我在使用insert函数时遇到了问题
- C++中函数的向量返回类型引发错误
- 添加存储在向量中的大整数的函数出现问题
- 如何在 c++ 中定义接受不同参数类型的函数向量?
- 具有 lambda 函数的函数向量
- 你能用参数制作函数向量吗?
- 在C++中使用成员函数向量时,有没有办法实现协变返回类型
- 在编写 lambda 函数向量时出现隔离错误
- 如何在 boost.process 间共享内存中使用复杂结构"push_back"函数向量
- 是否将std矢量重新分配到默认的构造函数向量是擦除的好方法
- 运行提升for_each中的成员函数向量
- 创建和回推函数向量
- C++,指向函数向量的指针的STL映射