我的编程空间,编程开发者的网络收藏夹
学习永远不晚

带你了解C++中vector的用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

带你了解C++中vector的用法

一,什么是vector

vector(向量)是一个封装了动态大小数组的顺序容器。能够存放各种类型的对象(注:一个容器中所有对象必须是同一种类型的)。可认为vector是一个能够存放任意类型的动态数组,可添加和删除数据(因为动态,所以相比数组节省空间)。

c++ primer的作者说到,在实际的编程中,我们作为程序员应该避免用到低级数组和指针,而更应该多用高级的vector和迭代器。

二,容器特性

1,顺序序列

顺序容器中的元素按照严格的线性顺序排序。可以通过元素在序列中的位置访问对应的元素。

2,动态数组

支持对序列中的任意元素进行快速直接访问,可通过指针进行该操作。提供在序列末尾增加/删除元素的操作。

3,能够感知内存分配器

容器使用一个内存分配器对象来动态地处理它的存储需求。

三,常用基本函数实现

vector(): 构造函数,创建一个空vector

vector(int nSize): 创建一个vector,元素个数为nSize

vector(int nSize,const t& t): 创建一个vector,元素个数为nSize,且值均为t

vector(begin,end): 复制[begin,end)区间内另一个数组的元素到vector中

~vector(): 析构函数,销毁容器对象并回收所有分配内存

void push_back(const T& x): 向量尾部增加一个元素X

iterator insert(iterator it,const T& x): 向量中迭代器指向元素前增加一个元素x

iterator insert(iterator it,int n,const T& x): 向量中迭代器指向元素前增加n个相同的元素x

iterator insert(iterator it,const_iterator first,const_iterator last): 向量中迭代器指向元素前插入另一个相同类型向量的[first,last)间的数据

iterator erase(iterator it): 删除向量中迭代器指向元素

iterator erase(iterator first,iterator last): 删除向量中[first,last)中元素

void pop_back(): 删除向量中最后一个元素

void clear(): 清空向量中所有元素,即size值全部为0,但存储空间没有改变(释放)

reference at(int pos): 返回pos位置元素的引用

reference front(): 返回首元素的引用

reference back(): 返回尾元素的引用

iterator begin(): 返回向量头指针,指向第一个元素

iterator end(): 返回向量尾指针,指向向量最后一个元素的下一个位置

bool empty() const: 判断向量是否为空,若为空,则向量中无元素

int size() const: 返回向量中元素的个数

int capacity() const: 返回当前向量所能容纳的最大元素值

int max_size() const: 返回最大可允许的vector元素数量值

void swap(vector&): 交换两个同类型向量的数据,交换两个容器内容,涉及存储空间分配问题

void assign(int n,const T& x): 设置向量中前n个元素的值为x

void assign(const_iterator first,const_iterator last): 向量中[first,last)中元素设置成当前向量元素

四,基本用法

1,头文件

vector是C++标准库STL中的数据结构,因此要使用vector,需要在程序头添加:

#include <vector>
using namespace std;

2,创建和使用

创建vector对象

//创建一个普通一维动态数组
vector<int> vec;
//创建一个二维动态数组
vector<vector<int>> vec2;
//尾部插入数字:
vec.push_back(1);
//尾部删除数字:
vec.pop_back();
//使用下标访问数组,下标从0开始
cout<<vec[0]<<endl;
//使用迭代器访问元素
vector<int>::iterator it;
for(it = vec.begin();it != vec.end();it++){
	cout<< *it <<endl;
}
//插入元素
vec.insert(vec.begin()+i,a);
//删除元素
vec.erase(vec.begin()+i);
vec.erase(vec.begin()+i,vec.end()+j);
//向量大小:
vec.size();
//清空向量:
vec.clear();

vector的元素可以是int,double,string,结构体,注意:结构体要定义为全局的,否则会出错。

3,算法

(1) 使用reverse将元素翻转:

// 需要头文件 
#include <algorithm>
reverse(vec.begin(),vec.end());

(2)使用 sort 排序:

// 需要头文件
#include<algorithm>,
sort(vec.begin(),vec.end());(默认是按升序排列,即从小到大).

五,vector占用内存空间问题

1,vector内存自增长

与其他容器不同,其内存空间只会增长,不会减小。

为了支持快速的随机访问,vector容器的元素以连续方式存放,每一个元素都紧挨着前一个元素存储。设想一下,当vector添加一个元素时,为了满足连续存放这个特性,都需要重新分配空间、拷贝元素、撤销旧空间,这样性能难以接受。

因此STL实现者在对vector进行内存分配时,其实际分配的容量要比当前所需的空间多一些。就是说,vector容器预留了一些额外的存储区,用于存放新添加的元素,这样就不必为每个新元素重新分配整个容器的内存空间。

每当vector容器不得不分配新的存储空间时,会以加倍当前容量的分配策略实现重新分配。

2,vector内存释放

所有内存空间是在vector析构时候才能被系统回收。empty()用来检测容器是否为空的,clear()可以清空所有元素,但无法释放内存。如果需要空间动态缩小,可以考虑使用deque或者使用其他容器。

六,疑问解答

1,vector与数组的区别

相同点:

都是可以对同一种类型数据进行存储

都可以用迭代器操作

都可以通过下标进行数据处理

不同点:

vector动态长度,可通过push_back和pop_back方法增加和缩短长度;数组长度在定义时已经确定,不可更改

vector的下标必须是无符号数;数组下标可以是有符号数

2,C++11关于vector的新增特性有:

a.cbegin();    // 返回指向容器中第一个元素的const_iterator
a.cend();      // 返回指向容器中最后一个元素的const_iterator
a.crbegin();   // 反转迭代器, 返回指向容器中最后一个元素的const_iterator
a.crend();     // 反转迭代器, 返回指向容器中第一个元素的const_iterator
a.emplace();   // 类似insert功能,但比它更有效率
a.emplace_back(); //类似push_back, 但比它更有效率

总结

到此这篇关于带你了解C++中vector的用法的文章就介绍到这了,更多相关C++ vector用法内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

带你了解C++中vector的用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

一文带你了解C++中queue的使用

C++中的queue是一种容器,用于在FIFO(先进先出)原则下存储和管理元素。本篇文章将深入探讨C++中的queue,包括它的定义、使用、原理和示例,感兴趣的可以了解一下
2023-05-18

一文带你了解C++中deque的使用

C++中的deque是一种双端队列,可以在队列的前端和后端进行插入元素和删除操作,同时可以视作一个长度不定的数组,支持高效的插入和删除操作。本篇文章将深入探讨C++中的deque的使用,感兴趣的可以了解一下
2023-05-18

一文带你了解C++中的字符替换方法

这篇文章主要为大家详细介绍了C++中常用的几个字符替换方法,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以跟随小编一起了解一下
2023-05-18

一文带你了解C#操作MySql的方法

工作中大多数情况下用的都是MySql但一直没有记录,相关操作。这篇文章以便MySql.Data库进行MySql操作,使用C#执行SQL语句,造个轮子
2023-03-20

一文带你了解Vue3中toRef和toRefs的用法

Vue3中toRef、toRefs都是与响应式数据相关的,本文主要来给大家讲解一下Vue3中的toRef和toRefs的使用,感兴趣的朋友跟随小编一起看看吧
2023-01-30

一文带你快速了解C/C++标准库中的ptrdiff_t

ptrdiff_t是C/C++标准库中定义的一个与机器相关的数据类型,ptrdiff_t类型变量通常用来保存两个指针减法操作的结果,下面这篇文章主要给大家介绍了关于C/C++标准库中ptrdiff_t的相关资料,需要的朋友可以参考下
2022-11-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录