c++将vector迭代器转换为指针的实现方式

目录
  • 将vector迭代器转换为指针
  • vector与迭代器的使用
    • 1. 标准库vector
    • 2. 迭代器

将vector迭代器转换为指针

定义一个Domain结构体以及容器、迭代器

struct Domain{
	int ID;
	string name
	string description;
};
vector <struct Domain> domainVec;
int main(){
	...
	vector <struct Domain>::iterator iter=domainVec.begin();
	...
return 0;
}

若要从迭代器iter中取出特定元素,可以使用

struct Domain domain=*iter;

指针相对于变量,可以通过删除指针,赋值NULL这种编程技巧,表示指针所指向的变量不可用或已失效。而变量就没有这种特性了,变量是永远有值的。

转化成指针,就需要使用如下形式

struct domain *pDomain=&*iter;

但是此时pDomain成为一个危险的指针,可以通过pDomain++、pDomain--等形式访问domainVec容器中的内容,容易出现越界等错误。

应该注意

cout<<"domain ID="<<p->ID<<endl;
p++;
p++;
...
cout<<"domain ID="<<p->ID<<endl;

迭代器对容器删除等操作。可能造成此指针指向的内容改变!

vector与迭代器的使用

这是《C++ Primer》第五版关于vector和迭代器的读书笔记

!!!本文的源码均来自于《C++ Primer》第五版!!!(可能会稍作修改)

The source codes in this article are all from C++ Primer, The Fifth Edition

1. 标准库vector

vector:一个支持自动扩容,基于数组的容器

vector的初始化:截图来自于《C++ Primer》第五版,P87

vector的操作:截图来自于《C++ Primer》第五版,P91

2. 迭代器

迭代器(iterator):迭代器用于迭代访问标准库容器(例如vector)和string中的元素

2.1. 获取和使用迭代器

  • begin函数:基本所有标准库容器都有这个成员函数,它返回一个位于容器首个元素位置的迭代器,成为首迭代器
  • end函数:基本所有标准库容器都有这个成员函数,它返回一个位于容器末尾元素后一个位置的迭代器,成为尾迭代器(也就是说,end指向的内容不存在与容器中,它指向一个“尾后”的位置)
  • 容器为空:如果容器为空,那么首迭代器和尾迭代器都指向“尾后”
vector<int> v{1, 2, 3, 4, 5}
auto b = v.begin(), e = v.end();	// 创建两个迭代器,一个首迭代器,一个尾迭代器

迭代器运算符:截图来自于《C++ Primer》第五版,P96

解引迭代器访问&更改元素:用解引用符来访问迭代器指向的内容

string s1("ABC");
for (auto it = s1.begin(); it != s1.end(); it++)
{
	*it = tolower(*it);
}
cout << s1 << endl;		// 输出“abc”

箭头运算符访问成员:通过箭头运算符,我们可以直接访问迭代器指向内容的成员,而不用先解引再访问

vector<string> v1{"hello", "hi"};
auto it = v1.begin();

// 下面两行代码的功能是一样的
cout << (*it).size() << endl;	// 输出“5”
cout << it->size() << endl;		// 输出“5”

2.2. 迭代器的类型

  • iterator类型:可以读取并写入元素的迭代器,类似指针一样的存在
  • const_iterator类型:只能读取元素,不能写入元素的迭代器,类似指向常量的指针
  • 常量对象迭代器为const_iterator:若我们定义一个常量,并构造它的迭代器,那么auto会判断它为const_iteratorcbegin()和cend():与begin()和end()类似,唯一的不同点在于cbegin()和cend()返回的迭代器类型必为const_iterator
const vector<int> myVec;
auto it = myVec.begin();	// it的类型为const_iterator

迭代器失效:若在使用迭代器时,更改了容器的元素数量(加入或者删除元素),那么迭代器会失效,因为很有可能迭代器指向的内容将不复存在亦或者错位

2.3. 迭代器运算

迭代器常用运算:截图来自于《C++ Primer》第五版,P99

迭代器和二分查找:十分出名的二分查找法可以用迭代器快速实现,使用迭代器的好处在于不用处理元素下标,因为经验不丰富的程序员很容易在使用下标时发生下标超限(Index Out of Range)或者缓存溢出问题(Buffer Overflow)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • C++ vector容器 find erase的使用操作:查找并删除指定元素

    概念:容器.迭代器.算法 STL包括容器.迭代器和算法: 容器 用于管理一些相关的数据类型.每种容器都有它的优缺点,不同的容器反映出程序设计的不同需求.容器自身可能由数组或链表实现,或者容器中的每个元素都有特殊的关键值. 迭代器 用于遍历一个数据集中的每个元素.这些数据集可能是容器或者容器的子集.迭代器的主要优点是它们为任意类型的容器提供一个小巧并且通用(注意通用很重要)的接口.例如,迭代器接口的一个操作是让它依次遍历数据集的每个元素.这个操作是依赖容器的内总部结构独立完成的.迭代器之所以有效是

  • C++ vector 遍历的几种方法

    目录 1.迭代器 2.C++11 新增关键字auto 3.数组遍历法 4.基于范围的for循环 C++ vector遍历demo,多种姿势任你选~ 1.迭代器 for(vector<int>::iterator it = obj.begin(); it != obj.end(); it++) { cout << *it << ","; } 2.C++11 新增关键字auto for(auto it = obj.begin(); it != obj.e

  • C++ 中boost::share_ptr智能指针的使用方法

    C++ 中boost::share_ptr智能指针的使用方法 最近项目中使用boost库的智能指针,感觉智能指针还是蛮强大的,在此贴出自己学习过程中编写的测试代码,以供其他想了解boost智能指针的朋友参考,有讲得不正确之处欢迎指出讨论.当然,使用boost智能指针首先要编译boost库,具体方法可以网上查询,在此不再赘述. 智能指针能够使C++的开发简单化,主要是它能够自动管理内存的释放,而且能够做更多的事情,即使用智能指针,则可以再代码中new了之后不用delete,智能指针自己会帮助你管理

  • c++将vector迭代器转换为指针的实现方式

    目录 将vector迭代器转换为指针 vector与迭代器的使用 1. 标准库vector 2. 迭代器 将vector迭代器转换为指针 定义一个Domain结构体以及容器.迭代器 struct Domain{ int ID; string name string description; }; vector <struct Domain> domainVec; int main(){ ... vector <struct Domain>::iterator iter=domain

  • 关于vector迭代器失效的几种情况总结

    在泛型编程还是STL的实际运用中,迭代器(iterator)无疑扮演者重要的角色.迭代器是一种类似于指针的对象(如可以内容提领,成员访问等),但他又不仅仅是一种普通的指针. 关于迭代器失效,我们可以看下面这个例子: #include<vector> #include<list> void PrintVector(const vector<int>& v) { vector<int>::const_iterator it = v.begin(); wh

  • C++中vector迭代器失效问题详解

    目录 问题: (1)删除vector中所有的偶数 (2)vector容器插入元素问题 迭代器失效原因 解决: 总结 问题: (1)删除vector中所有的偶数 #include <iostream> #include <vector> using namespace std; int main() { vector<int> vec; for (int i = 0; i < 10; ++i) { vec.push_back(i); } //把vec容器中的所有偶数

  • C++ Vector迭代器失效问题的解决方法

    目录 一.迭代器失效 二.可能引起的迭代器失效的操作 2.1.野指针引起迭代器失效 2.2.迭代器指向的位置意义改变 2.3.总结 一.迭代器失效 主要作用就是让算法能够不用关心底层数据结构,其底层实际就是一个指针,或者是对指针进行了封装.比如:vector的迭代器就是原生态指针T*.因此迭代器失效,实际就是迭代器底层对应指针所指向的空间被销毁了,而使用一块已经被释放的空间,造成的后果是程序崩溃(即如果继续使用已经失效的迭代器,程序可能会崩溃). 二.可能引起的迭代器失效的操作 2.1.野指针引

  • Python中Timedelta转换为Int或Float方式

    目录 Timedelta转换为Int或Float方式 Pandas处理 Numpy处理 区别 timedelta.float 互转 Timedelta转换为Int或Float方式 Pandas处理 import pandas as pd dataSet['t'] =dataSet['time'].astype('timedelta64[D]').astype(float) dataSet['t'] .head() Numpy处理 import numpy as np dataSet['t']=(

  • javascript引用类型指针的工作方式

    先看个例子: <script> var a = {n:1}; var b = a; a.x = a = {n:2}; console.log(a.x);// --> undefined console.log(b.x);// --> [object Object] </script> 上面的例子看似简单,但结果并不好了解,很容易把人们给想绕了--"a.x不是指向对象a了么?为啥log(a.x)是undefined?"."b.x不是应该跟a.

  • C++ vector的用法小结

    c++ vector用法 C++内置的数组支持容器的机制,但是它不支持容器抽象的语义.要解决此问题我们自己实现这样的类.在标准C++中,用容器向量(vector)实现.容器向量也是一个类模板. 标准库vector类型使用需要的头文件:#include <vector>.vector 是一个类模板.不是一种数据类型,vector<int>是一种数据类型.Vector的存储空间是连续的,list不是连续存储的. 一. 定义和初始化 vector< typeName > v1

  • 浅谈c++ stl迭代器失效的问题

    之前看<C++ Primier>的时候,也解到在顺序型窗口里insert/erase会涉及到迭代器失效的问题,并没有深究.今天写程序的时候遇到了这个问题. 1 莫名其妙的Erase 最初我的程序是酱紫的,别说话,我知道这样是有问题的,可这样是最直观的想法 int arr[]={0,1,2,3,4,5,6,7,8,9,10}; vector<int> a(arr,arr+sizeof(arr)/sizeof(*arr));for (auto it = a.begin(); it !=

  • 关于C++中vector的两个小tips分享

    前言 本来这篇文章标题我想起成<关于 vector 的两个小坑>,后来想想,其实也不算是坑,还是自己对原理性的东西理解的没做那么透彻.工作中遇到的很多问题,后来归根到底都是基础不牢靠. vector 扩容 这个问题很经典了,但还是不小心踩到.有一个需求是要对目标元素进行复制,而目标元素集合是保存在 vector 里面,于是简单思考下就有如下代码(大致含义): void Duplidate(vector<Element>* element_list, Element* element

随机推荐