当前位置: 首页 > news >正文

[C++初阶]vector的初步理解

一、标准库中的vector类

1.vector的介绍

1. vector是表示可变大小数组的序列容器 和数组一样,vector可采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问,和数组一样高效。但是又不像数组,它的大小是可以动态改变的,而且它的大小会被容器自动处理。
2. 本质讲,vector使用动态分配数组来存储它的元素。当新元素插入时候,这个数组需要被重新分配大小,以增加存储空间。其做法是:分配一个新的数组,然后将全部元素移到这个数组。就时间而言,这是一个代价相对来说高的任务,因为每当一个新的元素加入到容器的时候,vector并不会每次都重新分配大小。
3. vector分配空间策略:vector会分配一些额外的空间以适应可能的增长,因为存储空间比实际需要的存储空间更大。不同的库采用不同的策略权衡空间的使用和重新分配。但是无论如何,重新分配都应该是对数增长的间隔大小,以至于在末尾插入一个元素的时候是在常数时间的复杂度完成的。
4. 因此,vector占用了更多的存储空间,为了获得管理存储空间的能力,并且以一种有效的方式动态增长。
5. 与其它动态序列容器相比(deque, list and forward_list), vector在访问元素的时候更加高效,在末尾添加和删除元素相对高效。对于其它不在末尾的删除和插入操作,效率更低。比起list和forward_list统一的迭代器和引用更好 
我们知道STL学习的三步:能用,明理,能扩展,因而我们的学习也是这个流程

2.vector的使用

记住,学stl一定一定要学会看文档,vector文档.vector在实际中非常的重要,在实际中我们熟悉常

见的接口就可以。

2.1 常用的构造函数

vector();

vector类的默认构造函数,构造一个没有元素的空容器

例如:

void test()
{vector<int> v;
}

需要引用头文件vector


vector(size_type n, const value_type& val = value_type());

构造一个vector类对象并用n个val初始化

例如:

void test()
{//vector<int> v;vector <int> v(5, 0);for (auto i : v){cout << i << " ";}
}
int main()
{test();return 0;
}

运行结果:

void test()
{//vector<int> v;vector <int> v(5, 2);for (auto i : v){cout << i << " ";}
}
int main()
{test();return 0;
}

运行结果:


拷贝构造函数

vector(const vector& x);

对于一个已有的vector容器进行拷贝,并生成一个新的容器

例如:

void test()
{//vector<int> v;vector <int> v1(5, 2);vector <int> v2(v1);for (auto i : v2){cout << i << " ";}
}

运行结果:v


使用迭代器的初始化构造

Template<class InputIterator>vector(InputIterator first, InputIterator last);

例如:

void test()
{//vector<int> v;vector <int> v1(5, 2);//vector <int> v2(v1);vector <int> v2(v1.begin(),v1.end()-1);for (auto i : v2){cout << i << " ";}
}

运行结果v:

2.2 容量操作的接口

1.size
size_type size() const;

获取有效元素的个数

例如:

void test()
{//vector<int> v;vector <int> v1(5, 2);//vector <int> v2(v1);/*vector <int> v2(v1.begin(),v1.end()-1);*///for (auto i : v2)//{//	cout << i << " ";//}cout << v1.size();
}
int main()
{test();return 0;
}

运行结果:

2.capacity

获取容量大小

size_type capacity() const;

例如:

void test()
{vector <int> v1(5, 2);cout << v1.capacity();
}

运行结果:

3.empty

判断容器是否为空

bool empty() const;

例如:

​
void test()
{vector <int> v1(5, 2);vector <int> v2;cout << v1.empty() << endl;cout << v2.empty() << endl;
}​

运行结果:

4.resize
void resize (size_type n, value_type val = value_type());

将有效元素的个数修改为n,并且如果n大于原来的size,多出来的地方用val填充

如果没有给出val,就用0填充

例如:

void test()
{vector <int> v;cout << v.size() << endl;v.resize(20);cout << v.size() << endl;for (auto i : v){cout << i << " ";}cout << endl;v.resize(30);cout << v.size() << endl;for (auto i : v){cout << i << " ";}cout << endl;v.resize(10);cout << v.size() << endl;for (auto i : v){cout << i << " ";}
}

运行结果:

5.max_size
size_type max_size() const;

返回最大大小

例如:

ps:这里push_back是尾插

void test1()
{vector <int> v;for (int i = 0; i < 100; i++) v.push_back(i);cout << v.size() << endl;
}

运行结果:

6.reserve​​​​​
void reserve (size_type n);

改变容量大小

例如:

void test1()
{vector <int> v;cout << v.capacity() << endl;v.reserve(10);cout << v.capacity() << endl;
}

运行结果:

2.3vector的访问及其遍历

1.operator[]
reference operator[] (size_type n);
const_reference operator[] (size_type n) const;

用下标直接访问

例如:

void test()
{vector <int> v(5,2);cout << v[2] << endl;
}

运行结果:

因此我们也可以通过下标去遍历,这里就不多作演示

2.迭代器

这里大体和string类差不多

iterator begin();const_iterator begin() const;iterator end();const_iterator end() const;

迭代器,用于获取容器中第一个元素的位置和最后一个元素的下一个位置

例如:

​
void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,1 };vector<int>::iterator it = v.begin();while (it != v.end()){cout << *it << " ";++it;}
}​

运行结果:

3.反向迭代器

这个整体和迭代器差不多

reverse_iterator rbegin();const_reverse_iterator rbegin() const;reverse_iterator rend();const_reverse_iterator rend() const;

rbegin获取容器中最后一个元素的位置,rend获取容器中的第一个元素的前一个位置

例如:

​
void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,1 };vector<int>::reverse_iterator rit = v.rbegin();while (rit != v.rend()){cout << *rit << " ";++rit;}
}​

运行结果:

4.at
reference at (size_type n);
const_reference at (size_type n) const;

返回容器中位置n处的元素的引用

例如:

void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,1 };cout << v.at(5) << endl;for (size_t i=0;i<v.size();++i){cout << v.at(i) << " ";}
}

运行结果:

5.back
reference back();
const_reference back() const;

返回容器中最后一个元素的引用

例如:

void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,123 };cout << v.back()<< endl;
}

运行结果:

6.front
reference front();
const_reference front() const;

返回容器中第一个元素的引用

例如:

void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,123 };cout << v.front()<< endl;
}

运行结果:

2.4vector的增删查改

1.push_back();
void push_back(const value_type& val);

从容器尾部插入一个元素

例如:

void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,123 };cout << v.back()<< endl;v.push_back(99999);cout << v.back() << endl;
}

运行结果:

2.pop_back()
void test()
{vector <int> v = { 1,2,3,4,5,67,8,9,0,123 };cout << v.back()<< endl;v.pop_back();cout << v.back() << endl;
}

运行结果:

3.find()
template <class InputIterator, class T>InputIterator find(InputIterator first, InputIterator last, const T& val);

在两个迭代器区间寻找val并返回其所在处的迭代器

例如:

void test2()
{vector<int> v = { 1,2,3,4,5,6 };for (auto i : v){cout << i << " ";}cout << endl;vector<int>::iterator it = find(v.begin(), v.end(), 3);*it = 30;for (auto i : v){cout << i << " ";}cout << endl;
}

需要注意的是,该函数并非vector的成员函数,是标准库中的函数,多个容器共用该find函数

4.insert()
iterator insert (iterator position, const value_type& val);
void insert (iterator position, size_type n, const value_type& val);template <class InputIterator>    
void insert (iterator position, InputIterator first, InputIterator last);

在position位置插入元素

例如:

void test2()
{vector<int> v = { 1,2,3,4,5,6 };for (auto i : v){cout << i << " ";}cout << endl;vector<int>::iterator it = find(v.begin(), v.end(), 3);v.insert(it, 99999);for (auto i : v){cout << i << " ";}cout << endl;
}

运行结果:

5.earse()
iterator erase (iterator position);
iterator erase (iterator first, iterator last);

删除position位置的元素或者 [first,last) 区间的所有元素

例如:

void test2()
{vector<int> v = { 1,2,3,4,5,6 };for (auto i : v){cout << i << " ";}cout << endl;vector<int>::iterator it = find(v.begin(), v.end(), 3);v.erase(it);for (auto i : v){cout << i << " ";}cout << endl;
}

运行结果:

6.swap()
void swap (vector& x);

交换两个vector的数据空间

例如:

void test3()
{vector<int> v1 = { 1,2,3,4,5,6,7,8,9,0 };vector<int> v2 = { 0,9,8,7,6,5,4,3,2,1 };v1.swap(v2);for (auto i : v1){cout << i << " ";}cout << endl;
}

运行结果:

7.assign()
template <class InputIterator>  void assign (InputIterator first, InputIterator last);
void assign (size_type n, const value_type& val);

为vector指定新内容,替换其当前内容并修改size

例如:

void test2()
{vector<int> v = { 1,2,3,4,5,6 };for (auto i : v){cout << i << " ";}cout << endl;v.assign(5, 4);for (auto i : v){cout << i << " ";}cout << endl;
}

运行结果:

8.clear()
void clear();

从vector中删除所有元素,不改变容量大小

例如:

void test2()
{vector<int> v = { 1,2,3,4,5,6 };for (auto i : v){cout << i << " ";}cout << "size:" << v.size();cout << endl;v.clear();for (auto i : v){cout << i << " ";}cout << "size:" << v.size();cout << endl;
}

运行结果:


本篇是对vector的初步理解,我们只需知道会用即可

如有错误,欢迎大家在评论区指出。

相关文章:

[C++初阶]vector的初步理解

一、标准库中的vector类 1.vector的介绍 1. vector是表示可变大小数组的序列容器 &#xff0c; 和数组一样&#xff0c;vector可采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问&#xff0c;和数组一样高效。但是又不像数组&#xff0c;它的大…...

【等保2.0是什么意思?等保2.0的基本要求有哪些? 】

一、等保2.0是什么意思&#xff1f; 等保2.0又称“网络安全等级保护2.0”体系&#xff0c;它是国家的一项基本国策和基本制度。在1.0版本的基础上&#xff0c;等级保护标准以主动防御为重点&#xff0c;由被动防守转向安全可信&#xff0c;动态感知&#xff0c;以及事前、事中…...

VMware中的三种虚拟网络模式

虚拟机网络模式 1 主机网络环境2 VMware中的三种虚拟网络模式2.1 桥接模式2.2 NAT模式2.3 仅主机模式 3 网络模式选择及配置NAT模式3.1 VMware虚拟网络配置3.2 虚拟机选择网络模式3.3 Windows主机网络配置 4 配置静态IP 虚拟机联网方式为桥接模式&#xff0c;这种模式下&#x…...

深度学习基准模型Transformer

深度学习基准模型Transformer 深度学习基准模型Transformer&#xff0c;最初由Vaswani等人在2017年的论文《Attention is All You Need》中提出&#xff0c;是自然语言处理&#xff08;NLP&#xff09;领域的一个里程碑式模型。它在许多序列到序列&#xff08;seq2seq&#xf…...

如何实现公网环境远程连接本地局域网宝塔FTP服务远程管理文件

文章目录 前言1. Linux安装Cpolar2. 创建FTP公网地址3. 宝塔FTP服务设置4. FTP服务远程连接小结 5. 固定FTP公网地址6. 固定FTP地址连接 &#x1f4a1;推荐 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。…...

dledger原理源码分析系列(一)-架构,核心组件和rpc组件

简介 dledger是openmessaging的一个组件&#xff0c; raft算法实现&#xff0c;用于分布式日志&#xff0c;本系列分析dledger如何实现raft概念&#xff0c;以及dledger在rocketmq的应用 本系列使用dledger v0.40 本文分析dledger的架构&#xff0c;核心组件&#xff1b;rpc组…...

Github 2024-07-05开源项目日报 Top10

根据Github Trendings的统计,今日(2024-07-05统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目6TypeScript项目2Jupyter Notebook项目1Dart项目1C++项目1免费API集合 创建周期:2900 天开发语言:Python协议类型:MIT LicenseSta…...

WHAT - React useEffect 依赖的 Object.is

目录 一、背景二、Object.is 的语法三、Object.is 的行为四、总结 一、背景 在 https://react.dev/reference/react/useEffect 中我们了解到&#xff1a; React will compare each dependency with its previous value using the Object.is comparison. 接下来我们学习一下 Ob…...

【Java EE】Spring IOCDI

Spring IOC & DI 文章目录 Spring IOC & DI一、Spring是什么&#xff1f;二、IOC(控制反转)2.1 通俗理解2.2 造汽车的例子理解IOC2.3 IOC详解1. 获取Bean2. 方法注解——Bean1. 应用场景&#xff1a;2. 应用方法&#xff1a;3. 注意要点&#xff1a; 特别注意: 四、DI4…...

【FreeRTOS】同步互斥与通信 有缺陷的同步示例

目录 1 同步互斥与通信1.1 同步互斥与通信概述1.2 同步与互斥的概念1.3 同步的例子&#xff1a;有缺陷1.4 freertos.c源码3. 互斥的例子&#xff1a;有缺陷4. 通信的例子&#xff1a;有缺陷5. FreeRTOS的解决方案 1 同步互斥与通信 1.1 同步互斥与通信概述 参考《FreeRTOS入门…...

Lambda表达式讲解

简介: Lambda表达式的使用场景非常广泛,主要包括函数式编程、集合操作、排序、线程编程、GUI事件处理、数据处理、Web开发等。 函数式编程:Lambda表达式是函数式编程的重要特性,可以用于替代传统的匿名内部类,简化代码,提高可读性。 集合操作:Lambda表达式可以与集合…...

深入了解Linux中的dnsmasq:配置与优化指南

目录 安装dnsmasqUbuntu/DebianCentOS/RHELFedora 配置dnsmasq基本配置高级配置 启动和测试dnsmasq优化dnsmasq性能优化安全性优化 常见问题与故障排除无法解析域名DHCP分配失败 在Linux系统中&#xff0c; dnsmasq 是一个轻量级的网络服务&#xff0c;主要用于提供DNS缓存和D…...

【React】Ant Design -- Table分页功能实现

实现步骤 为Table组件指定pagination属性来展示分页效果在分页切换事件中获取到筛选表单中选中的数据使用当前页数据修改params参数依赖引起接口重新调用获取最新数据 const pageChange (page) > {// 拿到当前页参数 修改params 引起接口更新setParams({...params,page})…...

400G SR4和800G SR8光模块在AI集群中的应用

人工智能&#xff08;AI&#xff09;技术的快速发展下&#xff0c;AI集群的计算能力和数据传输需求不断提升。为了满足这一需求&#xff0c;光模块技术也在不断进步。高速率光模块作为新一代高速光通信解决方案&#xff0c;正在逐步应用于AI集群中&#xff0c;为其提供更高效、…...

ARM功耗管理软件之DVFSAVS

安全之安全(security)博客目录导读 思考&#xff1a;功耗管理软件栈及示例&#xff1f;WFI&WFE&#xff1f;时钟&电源树&#xff1f;DVFS&AVS&#xff1f; 目录 一、ARM功耗管理软件之DVFS 二、ARM功耗管理软件之AVS 一、ARM功耗管理软件之DVFS 有一个实现特定…...

【堆 优先队列】23. 合并 K 个升序链表

本文涉及知识点 堆 优先队列 LeetCode23. 合并 K 个升序链表 给你一个链表数组&#xff0c;每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中&#xff0c;返回合并后的链表。 示例 1&#xff1a; 输入&#xff1a;lists [[1,4,5],[1,3,4],[2,6]] 输出&#…...

云桌面运维工程师

一 深信服驻场工程师 1 深信服AC、AF、AD、NGAF、WOC Atrust、WAF项目实施经验者优先考虑。 负责云桌面POC测试 部署和配置&#xff1a;设置云桌面基础设施&#xff0c;包括虚拟化平台、云桌面管理软件和相关组件。确保正确配置网络、存储和安全设置。 用户体验&#xff1…...

AGI 之 【Hugging Face】 的【Transformer】的 [ Transformer 架构 ] / [ 编码器 ]的简单整理

AGI 之 【Hugging Face】 的【Transformer】的 [ Transformer 架构 ] / [ 编码器 ]的简单整理 目录 AGI 之 【Hugging Face】 的【Transformer】的 [ Transformer 架构 ] / [ 编码器 ]的简单整理 一、简单介绍 二、Transformer 三、Transformer架构 四、编码器 1、自注意…...

【在大模型RAG系统中应用知识图谱】

【引子】 关于大模型及其应用方面的文章层出不穷&#xff0c;聚焦于自己面对的问题&#xff0c;有针对性的阅读会有很多的启发&#xff0c;本文源自Whyhow.ai 上的一些文字和示例。对于在大模型应用过程中如何使用知识图谱比较有参考价值&#xff0c;特汇总分享给大家。 在基于…...

第二十条:与抽象类相比,优先选择接口

要定义多种实现的类型&#xff1a;JAVA有两种机制&#xff1a;接口和抽象类。这两种机制都支持为某些实例方法提供实现&#xff0c;但二者有个重要的区别&#xff1a;要实现由抽象类定义的类型&#xff0c;这个类必须是抽象类的子类。因为Java只允许单继承&#xff0c;对抽象类…...

19c补丁后oracle属主变化,导致不能识别磁盘组

补丁后服务器重启&#xff0c;数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后&#xff0c;存在与用户组权限相关的问题。具体表现为&#xff0c;Oracle 实例的运行用户&#xff08;oracle&#xff09;和集…...

大话软工笔记—需求分析概述

需求分析&#xff0c;就是要对需求调研收集到的资料信息逐个地进行拆分、研究&#xff0c;从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要&#xff0c;后续设计的依据主要来自于需求分析的成果&#xff0c;包括: 项目的目的…...

MongoDB学习和应用(高效的非关系型数据库)

一丶 MongoDB简介 对于社交类软件的功能&#xff0c;我们需要对它的功能特点进行分析&#xff1a; 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具&#xff1a; mysql&#xff1a;关系型数据库&am…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

OPENCV形态学基础之二腐蚀

一.腐蚀的原理 (图1) 数学表达式&#xff1a;dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一&#xff0c;腐蚀跟膨胀属于反向操作&#xff0c;膨胀是把图像图像变大&#xff0c;而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...

ABAP设计模式之---“简单设计原则(Simple Design)”

“Simple Design”&#xff08;简单设计&#xff09;是软件开发中的一个重要理念&#xff0c;倡导以最简单的方式实现软件功能&#xff0c;以确保代码清晰易懂、易维护&#xff0c;并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计&#xff0c;遵循“让事情保…...

Redis的发布订阅模式与专业的 MQ(如 Kafka, RabbitMQ)相比,优缺点是什么?适用于哪些场景?

Redis 的发布订阅&#xff08;Pub/Sub&#xff09;模式与专业的 MQ&#xff08;Message Queue&#xff09;如 Kafka、RabbitMQ 进行比较&#xff0c;核心的权衡点在于&#xff1a;简单与速度 vs. 可靠与功能。 下面我们详细展开对比。 Redis Pub/Sub 的核心特点 它是一个发后…...

Python 实现 Web 静态服务器(HTTP 协议)

目录 一、在本地启动 HTTP 服务器1. Windows 下安装 node.js1&#xff09;下载安装包2&#xff09;配置环境变量3&#xff09;安装镜像4&#xff09;node.js 的常用命令 2. 安装 http-server 服务3. 使用 http-server 开启服务1&#xff09;使用 http-server2&#xff09;详解 …...

spring Security对RBAC及其ABAC的支持使用

RBAC (基于角色的访问控制) RBAC (Role-Based Access Control) 是 Spring Security 中最常用的权限模型&#xff0c;它将权限分配给角色&#xff0c;再将角色分配给用户。 RBAC 核心实现 1. 数据库设计 users roles permissions ------- ------…...