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

C++初阶:容器(Containers)vector常用接口详解

介绍完了string类的相关内容后:C++初阶:适合新手的手撕string类(模拟实现string类)
接下来进入新的篇章,容器vector介绍:


文章目录

  • 1.vector的初步介绍
  • 2.vector的定义(constructor)
  • 3.vector迭代器( iterator )
  • 4.vector的三种遍历
    • 4.1正常for循环
    • 4.2范围for循环
    • 4.3两种迭代器(正向和反向)
  • 5.vector扩容相关(resize和reserve)
    • 5.2reserve()
    • 5.2resize()
  • 6. vector 增删查改
    • 6.1push_back和pop_back
    • 6.2find、Insert、erase
    • 6.3swap


1.vector的初步介绍

请添加图片描述

翻译过来就是:

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

2.vector的定义(constructor)

请添加图片描述

  1. 默认构造函数:explicit vector (const allocator_type& alloc = allocator_type())。这是默认构造函数,它创建一个空的 std::vector 对象。如果提供了分配器(allocator),则使用提供的分配器;否则使用默认分配器。
  2. 填充构造函数:explicit vector (size_type n, const value_type& val = value_type(), const allocator_type& alloc = allocator_type())。这个构造函数创建一个包含==n 个元素的 std::vector,每个元素的值都是 val ==。同样地,您可以选择提供一个分配器,如果没有提供,则使用默认分配器。
  3. 范围构造函数:template <class InputIterator> vector (InputIterator first, InputIterator last, const allocator_type& alloc = allocator_type())。这个构造函数使用迭代器范围[first, last) 中的元素来初始化 std::vector。这使得您可以使用另一个容器的一部分或全部元素来初始化 std::vector
  4. 复制构造函数:vector (const vector& x)。这个构造函数创建一个新的 std::vector,并使用另一个 std::vector x 中的元素进行初始化
构造函数声明接口说明
vector()(重点)无参构造
vector(size_type n, const value_type& val = value_type())构造并初始化n个val
vector(const vector& x)(重点)拷贝构造
vector(InputIterator first, InputIterator last)使用迭代器进行初始化构造
int main()
{vector<int> v1;//空参构造vector<int> v2(5, 1);//构造并初始化5个1vector<int> v3(v2);//拷贝构造string s1("abc");vector<int> v4(s1.begin(), s1.end());//使用迭代器进行初始化构造return 0;
}

请添加图片描述

这里v4中都存的是ASCII码值


3.vector迭代器( iterator )

请添加图片描述

迭代器说明
begin获取第一个数据位置的iterator/const_iterator
end获取最后一个数据的下一个位置的iterator/const_iterator
rbegin获取最后一个数据位置的reverse_iterator (反向迭代器的移动方向是与正向迭代器相反的,即 ++ 操作符会使迭代器向前移动,而 -- 操作符会使迭代器向后移动)
rend获取第一个数据前一个位置的reverse_iterator

4.vector的三种遍历

4.1正常for循环

void test2()
{string s1("abc");vector<char> v(s1.begin(), s1.end());//使用迭代器进行初始化构造for (size_t i = 0; i < v.size(); i++){cout << v[i] << " ";}
}int main()
{test2();
}

请添加图片描述

4.2范围for循环

void test3()
{string s1("abc");vector<int> v(s1.begin(), s1.end());//这里用int,不是charfor (auto e : v){cout << e << " ";}
}int main()
{test3();
}

请添加图片描述

4.3两种迭代器(正向和反向)

void test4()
{string s1("abc");vector<char> v(s1.begin(), s1.end());//使用迭代器进行初始化构造vector<char>::iterator it = v.begin();//正向遍历while (it != v.end()){cout << *it << " ";it++;}cout << endl;vector<char>::reverse_iterator rit = v.rbegin();//反向遍历while (rit != v.rend()){cout << *rit << " ";rit++;//是++不是--}//反向迭代器的移动方向是与正向迭代器相反的//即 ++ 操作符会使迭代器向前移动,而 -- 操作符会使迭代器向后移动
}int main()
{test4();
}

请添加图片描述


5.vector扩容相关(resize和reserve)

接口说明
size获取数据个数
capacity获取容量大小
empty判断是否为空
resize改变vector的size
reserve改变vector的capacity
  • capacity的代码在vs和g++下分别运行会发现,vs下capacity是按1.5倍增长的,g++是按2倍增长的。不要固化的认为,vector增容都是2倍,具体增长多少是根据具体的需求定义的。vs是PJ版本STL,g++是SGI版本STL。
  • reserve只负责开辟空间,如果确定知道需要用多少空间,reserve可以缓解vector增容的代价缺陷问题。
  • resize在开空间的同时还会进行初始化,影响size

5.2reserve()

请添加图片描述

reserve 函数用于改变容器的容量,即修改容器内部用于存储元素的空间大小。这个函数可以用来避免多次重新分配内存的开销,从而提高性能。但需要注意的是,reserve 只会增加容器的容量,而不会影响容器的大小

void test5()
{vector<int> v(10, 1);//10个1cout << v.capacity() << endl;v.reserve(20);cout << v.capacity() << endl;v.reserve(15);cout << v.capacity() << endl;v.reserve(5);cout << v.capacity() << endl;
}int main()
{test5();
}

请添加图片描述

5.2resize()

请添加图片描述

resize 函数用于改变容器的大小,即修改容器中元素的数量。如果将 resize 函数的参数设置为比当前大小小的值,那么容器将缩小到指定的大小,并丢弃多余的元素。如果将参数设置为比当前大小大的值,那么容器将增大到指定的大小,并且新元素不指明的话将被默认构造(对于内置类型,新元素将被初始化为 0)

void test6()
{vector<int> v(10, 1);//10个1cout << "capacity:" << v.capacity() << "size:" << v.size() << endl;v.resize(20);cout << "capacity:" << v.capacity() << "size:" << v.size() << endl;v.resize(15);cout << "capacity:" << v.capacity() << "size:" << v.size() << endl;v.resize(5);cout << "capacity:" << v.capacity() << "size:" << v.size() << endl;
}int main()
{test6();
}

请添加图片描述


6. vector 增删查改

接口说明
push_back尾部插入元素
pop_back尾部删除元素
find查找元素
insert在指定位置插入元素
erase删除指定位置的元素
swap交换两个 vector 的数据空间
operator[]像数组一样使用下标访问元素

6.1push_back和pop_back

请添加图片描述

void test7()
{vector<int> v(10, 1);//10个1for (auto e : v){cout << e << " ";}cout << endl;v.push_back(10);for (auto e : v){cout << e << " ";}cout << endl;v.pop_back();for (auto e : v){cout << e << " ";}cout << endl;
}int main()
{test7();
}

请添加图片描述

6.2find、Insert、erase

  1. find
    • 形式:iterator find (iterator first, iterator last, const T& val);
    • 参数说明:firstlast 表示查找范围的起始和结束迭代器;val 是要查找的值
    • 作用:在指定范围内查找指定的值,并返回第一个匹配元素的迭代器
  2. insert
    • 形式:iterator insert (iterator position, const T& val);
    • 参数说明:position 表示插入位置的迭代器;val 是要插入的值
    • 作用:在指定位置之前插入一个元素
  3. erase
    • 形式:iterator erase (iterator position);iterator erase (iterator first, iterator last);
    • 参数说明:position 表示要删除的位置的迭代器;firstlast 表示要删除的范围的起始和结束迭代器
    • 作用:删除指定位置的元素,或者指定范围内的元素
void test8()
{vector<int> v;for (int i = 1; i < 6; i++){v.push_back(i);}for (auto e : v){cout << e << " ";}cout << endl;vector<int>::iterator it = find(v.begin(), v.end(), 3);//找到3的位置v.insert(it, 0);//插入for (auto e : v){cout << e << " ";}cout << endl;v.erase(v.begin(),v.end());//全删了for (auto e : v){cout << e << " ";}cout << endl;
}int main()
{test8();
}

请添加图片描述

6.3swap

swap

  • 形式:void swap (vector& x);
  • 参数说明:x 是另一个 vector
  • 作用:交换两个 vector 的数据空间,使它们的内容互相交换
void test9()
{vector<int> v1;for (int i = 1; i < 6; i++){v1.push_back(i);}vector<int> v2(10, 1);cout << "还没交换" << endl;for (auto e : v1){cout << e << " ";}cout << endl;v1.swap(v2);//二者交换cout << "交换后" << endl;for (auto e : v1){cout << e << " ";}cout << endl;
}int main()
{test9();
}

请添加图片描述


常用的接口就这些了,下次就来进行模拟实现了,感谢大家支持!!!

相关文章:

C++初阶:容器(Containers)vector常用接口详解

介绍完了string类的相关内容后&#xff1a;C初阶&#xff1a;适合新手的手撕string类&#xff08;模拟实现string类&#xff09; 接下来进入新的篇章&#xff0c;容器vector介绍&#xff1a; 文章目录 1.vector的初步介绍2.vector的定义&#xff08;constructor&#xff09;3.v…...

flink写入es的参数解析

ElasticsearchSink内部使用BulkProcessor一次将一批动作(ActionRequest)发送到ES集群。在发送批量动作前&#xff0c;BulkProcessor先缓存&#xff0c;再刷新。缓存刷新的间隔&#xff0c;支持基于Action数量、基于Action大小、基于时间间隔3种策略。BulkProcessor支持在同一次…...

逆向工程:揭开科技神秘面纱的艺术

在当今这个科技飞速发展的时代&#xff0c;我们每天都在与各种电子产品、软件应用打交道。然而&#xff0c;你是否想过&#xff0c;这些看似复杂的高科技产品是如何被创造出来的&#xff1f;今天&#xff0c;我们就来探讨一下逆向工程这一神秘而又令人着迷的领域。 一、什么是…...

决策树的相关知识点

&#x1f4d5;参考&#xff1a;ysu老师课件西瓜书 1.决策树的基本概念 【决策树】&#xff1a;决策树是一种描述对样本数据进行分类的树形结构模型&#xff0c;由节点和有向边组成。其中每个内部节点表示一个属性上的判断&#xff0c;每个分支代表一个判断结果的输出&#xff…...

【数据结构】单向链表实现 超详细

目录 一. 单链表的实现 1.准备工作及其注意事项 1.1 先创建三个文件 1.2 注意事项&#xff1a;帮助高效记忆和理解 2.链表的基本功能接口 2.0 创建一个 链表 2.1 链表的打印 3.链表的创建新节点接口 4.链表的节点插入功能接口 4.1 尾插接口 4.2 头插接口 4.3 指定位…...

Opencc4j 开源中文繁简体使用介绍

Opencc4j Opencc4j 支持中文繁简体转换&#xff0c;考虑到词组级别。 Features 特点 严格区分「一简对多繁」和「一简对多异」。 完全兼容异体字&#xff0c;可以实现动态替换。 严格审校一简对多繁词条&#xff0c;原则为「能分则不合」。 词库和函数库完全分离&#xff0c…...

vue 下载二进制文件

文章目录 概要技术细节 概要 vue 下载后端返回的二进制文件流 技术细节 import axios from "axios"; const baseUrl process.env.VUE_APP_BASE_API; //downLoadPdf("/pdf/download?pdfName" res .pdf, res); export function downLoadPdf(str, fil…...

数据结构之堆排序

对于几个元素的关键字序列{K1&#xff0c;K2&#xff0c;…&#xff0c;Kn}&#xff0c;当且仅当满足下列关系时称其为堆&#xff0c;其中 2i 和2i1应不大于n。 { K i ≤ K 2 i 1 K i ≤ K 2 i 或 { K i ≥ K 2 i 1 K i ≥ K 2 i {\huge \{}^{K_i≤K_{2i}} _{K_i≤K_{2i1}} …...

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之ScrollBar组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之ScrollBar组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、ScrollBar组件 鸿蒙&#xff08;HarmonyOS&#xff09;滚动条组件ScrollBar&…...

读论文:DiffBIR: Towards Blind Image Restoration with Generative Diffusion Prior

DiffBIR 发表于2023年的ICCV&#xff0c;是一种基于生成扩散先验的盲图像恢复模型。它通过两个阶段的处理来去除图像的退化&#xff0c;并细化图像的细节。DiffBIR 的优势在于提供高质量的图像恢复结果&#xff0c;并且具有灵活的参数设置&#xff0c;可以在保真度和质量之间进…...

基于微信小程序的新生报到系统的研究与实现,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…...

分享一下 uniapp 打包安卓apk

首先需要安装 Java 环境&#xff0c;这里就不做解释了 第二步&#xff1a;打开 mac 终端 / cmd 命令行工具 使用keytool -genkey命令生成证书 keytool -genkey -alias testalias -keyalg RSA -keysize 2048 -validity 36500 -keystore test.keystore *testalias 是证书别名&am…...

DevOps落地笔记-21|业务价值:软件发布的最终目的

上一课时介绍如何度量软件的内部质量和外部质量。在外部质量中&#xff0c;我们提到用户满意度是衡量软件外部质量的关键因素。“敏捷宣言”的第一条原则规定&#xff1a;“我们最重要的目标&#xff0c;是通过持续不断的及早交付有价值的软件使用户满意”。从这一点也可以看出…...

【动态规划】【前缀和】【数学】2338. 统计理想数组的数目

作者推荐 【动态规划】【前缀和】【C算法】LCP 57. 打地鼠 本文涉及知识点 动态规划汇总 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 LeetCode:2338. 统计理想数组的数目 给你两个整数 n 和 maxValue &#xff0c;用于描述一个 理想…...

【已解决】onnx转换为rknn置信度大于1,图像出现乱框问题解决

前言 环境介绍&#xff1a; 1.编译环境 Ubuntu 18.04.5 LTS 2.RKNN版本 py3.8-rknn2-1.4.0 3.单板 迅为itop-3568开发板 一、现象 采用yolov5训练并将pt转换为onnx&#xff0c;再将onnx采用py3.8-rknn2-1.4.0推理转换为rknn出现置信度大于1&#xff0c;并且图像乱框问题…...

多路服务器技术如何处理大量并发请求?

在当今的互联网时代&#xff0c;随着用户数量的爆炸性增长和业务规模的扩大&#xff0c;多路服务器技术已成为处理大量并发请求的关键手段。多路服务器技术是一种并行处理技术&#xff0c;它可以通过多个服务器同时处理来自不同用户的请求&#xff0c;从而显著提高系统的整体性…...

SpringBoot - 不加 @EnableCaching 标签也一样可以在 Redis 中存储缓存?

网上文章都是说需要在 Application 上加 EnableCaching 注解才能让缓存使用 Redis&#xff0c;但是测试发现不用 EnableCaching 也可以使用 Redis&#xff0c;是网上文章有问题吗&#xff1f; 现在 Application 上用了 EnableAsync&#xff0c;SpringBootApplication&#xff0…...

Linux------命令行参数

目录 前言 一、main函数的参数 二、命令行控制实现计算器 三、实现touch指令 前言 当我们在命令行输入 ls -al &#xff0c;可以查看当前文件夹下所有文件的信息&#xff0c;还有其他的如rm&#xff0c;touch等指令&#xff0c;都可以帮我们完成相应的操作。 其实运行这些…...

LLM少样本示例的上下文学习在Text-to-SQL任务中的探索

导语 本文探索了如何通过各种提示设计策略&#xff0c;来增强大型语言模型&#xff08;LLMs&#xff09;在Few-shot In-context Learning中的文本到SQL转换能力。通过使用示例SQL查询的句法结构来检索演示示例&#xff0c;并选择同时追求多样性和相似性的示例可以提高性能&…...

双非本科准备秋招(19.2)—— 设计模式之保护式暂停

一、wait & notify wait能让线程进入waiting状态&#xff0c;这时候就需要比较一下和sleep的区别了。 sleep vs wait 1) sleep 是 Thread 方法&#xff0c;而 wait 是 Object 的方法 2) sleep 不需要强制和 synchronized 配合使用&#xff0c;但 wait 强制和 s…...

springboot 百货中心供应链管理系统小程序

一、前言 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;百货中心供应链管理系统被用户普遍使用&#xff0c;为方…...

【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器

一.自适应梯度算法Adagrad概述 Adagrad&#xff08;Adaptive Gradient Algorithm&#xff09;是一种自适应学习率的优化算法&#xff0c;由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率&#xff0c;适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...

工业安全零事故的智能守护者:一体化AI智能安防平台

前言&#xff1a; 通过AI视觉技术&#xff0c;为船厂提供全面的安全监控解决方案&#xff0c;涵盖交通违规检测、起重机轨道安全、非法入侵检测、盗窃防范、安全规范执行监控等多个方面&#xff0c;能够实现对应负责人反馈机制&#xff0c;并最终实现数据的统计报表。提升船厂…...

Spring Boot 实现流式响应(兼容 2.7.x)

在实际开发中&#xff0c;我们可能会遇到一些流式数据处理的场景&#xff0c;比如接收来自上游接口的 Server-Sent Events&#xff08;SSE&#xff09; 或 流式 JSON 内容&#xff0c;并将其原样中转给前端页面或客户端。这种情况下&#xff0c;传统的 RestTemplate 缓存机制会…...

3.3.1_1 检错编码(奇偶校验码)

从这节课开始&#xff0c;我们会探讨数据链路层的差错控制功能&#xff0c;差错控制功能的主要目标是要发现并且解决一个帧内部的位错误&#xff0c;我们需要使用特殊的编码技术去发现帧内部的位错误&#xff0c;当我们发现位错误之后&#xff0c;通常来说有两种解决方案。第一…...

可靠性+灵活性:电力载波技术在楼宇自控中的核心价值

可靠性灵活性&#xff1a;电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中&#xff0c;电力载波技术&#xff08;PLC&#xff09;凭借其独特的优势&#xff0c;正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据&#xff0c;无需额外布…...

[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)

前言&#xff1a; 最近在做行为检测相关的模型&#xff0c;用的是时空图卷积网络&#xff08;STGCN&#xff09;&#xff0c;但原有kinetic-400数据集数据质量较低&#xff0c;需要进行细粒度的标注&#xff0c;同时粗略搜了下已有开源工具基本都集中于图像分割这块&#xff0c…...

SQL慢可能是触发了ring buffer

简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...