当前位置: 首页 > 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;对抽象类…...

第19节 Node.js Express 框架

Express 是一个为Node.js设计的web开发框架&#xff0c;它基于nodejs平台。 Express 简介 Express是一个简洁而灵活的node.js Web应用框架, 提供了一系列强大特性帮助你创建各种Web应用&#xff0c;和丰富的HTTP工具。 使用Express可以快速地搭建一个完整功能的网站。 Expre…...

C++_核心编程_多态案例二-制作饮品

#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为&#xff1a;煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例&#xff0c;提供抽象制作饮品基类&#xff0c;提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

什么是EULA和DPA

文章目录 EULA&#xff08;End User License Agreement&#xff09;DPA&#xff08;Data Protection Agreement&#xff09;一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA&#xff08;End User License Agreement&#xff09; 定义&#xff1a; EULA即…...

高防服务器能够抵御哪些网络攻击呢?

高防服务器作为一种有着高度防御能力的服务器&#xff0c;可以帮助网站应对分布式拒绝服务攻击&#xff0c;有效识别和清理一些恶意的网络流量&#xff0c;为用户提供安全且稳定的网络环境&#xff0c;那么&#xff0c;高防服务器一般都可以抵御哪些网络攻击呢&#xff1f;下面…...

根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:

根据万维钢精英日课6的内容&#xff0c;使用AI&#xff08;2025&#xff09;可以参考以下方法&#xff1a; 四个洞见 模型已经比人聪明&#xff1a;以ChatGPT o3为代表的AI非常强大&#xff0c;能运用高级理论解释道理、引用最新学术论文&#xff0c;生成对顶尖科学家都有用的…...

【JavaWeb】Docker项目部署

引言 之前学习了Linux操作系统的常见命令&#xff0c;在Linux上安装软件&#xff0c;以及如何在Linux上部署一个单体项目&#xff0c;大多数同学都会有相同的感受&#xff0c;那就是麻烦。 核心体现在三点&#xff1a; 命令太多了&#xff0c;记不住 软件安装包名字复杂&…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

Typeerror: cannot read properties of undefined (reading ‘XXX‘)

最近需要在离线机器上运行软件&#xff0c;所以得把软件用docker打包起来&#xff0c;大部分功能都没问题&#xff0c;出了一个奇怪的事情。同样的代码&#xff0c;在本机上用vscode可以运行起来&#xff0c;但是打包之后在docker里出现了问题。使用的是dialog组件&#xff0c;…...