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

 更新时间:2022年11月11日 16:35:10   作者:百口可乐__  
这篇文章主要介绍了c++将vector迭代器转换为指针的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

将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)

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

相关文章

  • C++中new和delete的使用方法详解

    C++中new和delete的使用方法详解

    这篇文章主要介绍了C++中new和delete的使用方法详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • C语言选择排序算法及实例代码

    C语言选择排序算法及实例代码

    本篇文章主要介绍了 C语言选择排序算法,这里提供代码实例以便大家理解,通过本文,更好的理解排序算法
    2016-07-07
  • C语言实现简单登录操作

    C语言实现简单登录操作

    这篇文章主要为大家详细介绍了C语言实现简单登录操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • C++实现查找中位数的O(N)算法和Kmin算法

    C++实现查找中位数的O(N)算法和Kmin算法

    这篇文章主要介绍了C++实现查找中位数的O(N)算法和Kmin算法,对于C++程序算法设计有一定的借鉴价值,需要的朋友可以参考下
    2014-09-09
  • C语言数据存储归类介绍

    C语言数据存储归类介绍

    使用编程语言进行编程时,需要用到各种变量来存储各种信息。变量保留的是它所存储的值的内存位置。这意味着,当您创建一个变量时,就会在内存中保留一些空间。您可能需要存储各种数据类型的信息,操作系统会根据变量的数据类型,来分配内存和决定在保留内存中存储什么
    2022-08-08
  • 基于Matlab实现水波倒影特效的制作

    基于Matlab实现水波倒影特效的制作

    这篇文章主要介绍了如何利用Matlab制作出水波倒影的特效,文中的示例代码讲解详细,对我们学习Matlab有一定帮助,需要的可以参考一下
    2022-03-03
  • C语言中结构体变量私有化详解

    C语言中结构体变量私有化详解

    结构是由基本数据类型构成的、并用一个标识符来命名的各种变量的组合,下面这篇文章主要给大家介绍了关于C语言中结构体变量私有化的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-07-07
  • VC++开发中完美解决头文件相互包含问题的方法解析

    VC++开发中完美解决头文件相互包含问题的方法解析

    本文中,为了叙述方便,把class AClass;语句成为类AClass的声明,把class AClass开始的对AClass的类成员变量、成员函数原型等的说明称为类的定义,而把在CPP中的部分称为类的定义
    2013-09-09
  • C语言数据存储详解

    C语言数据存储详解

    在本篇文章里小编给大家整理的是关C语言数据存储,小编觉得这篇文章写的很不错,有需要的朋友们可以学习参考下,希望能够给你带来帮助
    2021-10-10
  • C++学习之如何进行内存资源管理

    C++学习之如何进行内存资源管理

    与java、golang等自带垃圾回收机制的语言不同,C++并不会自动回收内存,这往往会导致内存泄漏和内存溢出等问题,所以掌握C++中的内存管理技巧和工具是非常重要的,本文就来和大家详细讲讲
    2023-05-05

最新评论