C++:vector篇

前言:

        本篇仅介绍vector中常用的函数接口,如果需要详细的请到官网查看。

        vector是一种动态数组,能够自动调整大小。与数组类似,vector使用连续内存来存储元素,允许高效访问,但可以动态增加容量。为了应对容量增长,向量会在需要时重新分配内存,但这种重新分配是按对数级增长的,从而确保在末尾添加元素时操作平均时间复杂度为常数。

        与其他动态序列容器相比,向量在访问和在末尾添加或删除元素时最为高效,但在中间插入或删除元素时性能较差(与顺序表类似),并且链表(list)和双向链表,它的迭代器和引用一致性较差。

        并且vector是一个类模板,这就意味着vector可以同时存储不同类型的数据,如:int,char,甚至是自定义类型,如string。使用方式为 vector<类型> 变量。

       

        vector的成员变量:

源码取自:SGI-STL/The Annotated STL Sources V3.3/container/sequence container/vector/stl_vector.h at master · steveLauwh/SGI-STL (github.com)

        从上图看到,在vector中的成员变量不像之前的sting,他采用了三个类模板的指针变量,_start(开始) , _finish(完成), _end_of_storage(结尾的存储位置),分别对应了str的指针,top以及capacity。

vector相关的接口函数

        构造函数接口:

        

                1.vector ();无参构造

        可以看到,当使用无参构造时,vector里的数据以及容量都为0;

        2.vector (const vector& x);拷贝构造

        从上图可以看出,一开始创建了vector<int>类型的v1,并且通过push_back函数(这个函数后面会说明),对v1进行插值,接着又创建了v2并以v1为拷贝对象使用拷贝构造,使用范围for打印结果可以看出,v2把v1的数据进行了拷贝,并同时也进行了扩容的操作。

        迭代器接口函数

                1.iterator begin( )

                2.iterator end( )

        

        通常begin()函数与end()函数还是是拿来构建迭代器指针的,为后面的insert与erase做准备( 后面会说明),同时有了begin()函数与end()函数就可以使用迭代器遍历vector或使用范围for(底层就是迭代器)。

        关于容量的接口函数

                1.size_type size() const;返回vector对象的有效数据长度



        2.size_type capacity() const;返回vector对象的容量

        通过上图代码可以看到,当循环往v1中插入值,它的capacity是处于一个1.5倍的增长速度。

        3.void resize (size_type n);改变当前vector对象的size状态

                4.void reserve (size_type n); 改变vector的capacity状态

vector的增删改查函数接口

        1.void push_back (const value_type& val);尾插一个值

        2.void pop_back();尾删一个值

        从上图可以看到,pop_back会修改size中的数据,而并不会修改capacity的值,这是为了防止当对象再次插入值的时候又进行扩容而扩容就会付出一定的代价。

        

        3.iterator insert (iterator position, const value_type& val);pos位置插入一个值

        

        4.1 iterator erase (iterator position);

        

        4.2iterator erase (iterator first, iterator last);

关于vector中迭代器失效的问题:

        在 C++ 中,迭代器失效是一个重要的概念,指的是对容器进行修改操作(如插入、删除元素)时,可能导致原有迭代器变得无效,从而导致未定义行为。

        失效的原因

迭代器失效发生的主要原因是容器的底层数据结构被修改,导致原有的迭代器指向的内存位置发生变化。例如:

        插入操作:在某些容器中,插入操作可能会导致底层数据结构的重新分配(如 std::vector 的扩容),从而使所有迭代器失效。

        删除操作:删除元素可能会导致容器中元素的位置发生改变,从而使得指向被删除元素的迭代器失效。

        

        从上图可以看到当如果插入值时候,正好需要扩容,发生扩容后原数据会拷贝到新内存,而迭代器这里也只是传值不是传引用,在函数里的迭代器的改变不会影响主函数,所以此时it就变成了野指针,如果再继续使用就会有不可预知的风险。

        

        那么erase也是有同样的风险

        5.vector:operator[ ] 允许迭代器像数组一样访问其中的元素

                

                                                                                                  ————那么以上就是对于vector中小编的一些简单介绍,如有错误还请指出,感谢各位观看!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/407971.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

达梦数据库的系统视图v$tablespace

达梦数据库的系统视图v$tablespace 在达梦数据库&#xff08;DM Database&#xff09;中&#xff0c;V$TABLESPACE 提供了有关数据库中的表空间&#xff08;Tablespace&#xff09;信息。这些信息对于管理数据库存储和优化性能非常关键。表空间是数据库逻辑存储结构的一个层次…

12、stm32通过dht11读取温湿度

一、配置 二、代码 dht11.c /** dht11.c** Created on: Aug 19, 2024* Author: Administrator*/#include "main.h" #include "tim.h" #include "usart.h" #include "gpio.h" /**TIM3定时器实现us级延时*/ void Delay_us(uint16…

Midjourney提示词-动物系列-65

A super cute little anthropomorphic,sheep of the Chinese Zodiac, wearing berets ,in a Hanfu in red style,standing, eyes,cute tail,super realistic,super detail,luxurious,elegant,Unreal Engine,octane render, 8K,VRAY super realistic Pixar Style, Tiny cute…

[matlab]MATLAB实现MLP多层感知机minist手写识别预测

【测试环境】 matlab2023a 【源码文件截图】 【实现部分代码】 mlp_test.m %% MLP 2-layer to test XOR clear; clc;Mode MNIST %Mode XORif (strcmp(Mode,MNIST))% Load the digits into workspace (MNIST Test, from% http://yann.lecun.com/exdb/mnist/)num_train 100…

为什么要构建自己的 AI 代理库

上个月&#xff0c;我开始深入研究 AI 代理的世界。在探索这个领域时&#xff0c;我突然有了灵感&#xff1a;从现在开始我要研究 AI 代理。 最近&#xff0c;我一直在思考第二点。既然有很多可用的选项&#xff0c;为什么还要开发自己的 AI 代理库呢&#xff1f; 经过一番思…

SCI论文系统各阶段状态含义,一文带你全面掌握!告别投稿小白!

知识小站 SCI&#xff08;Science Citation Index&#xff0c;科学引文索引&#xff09;是由美国科学信息研究所&#xff08;Institute for Scientific Information, ISI&#xff09;创建的一个引文数据库。它收录了全球各学科领域中最具影响力的学术期刊&#xff0c;涵盖自然…

PyTorch深度学习模型训练流程的python实现:回归

回归的流程与分类基本一致&#xff0c;只需要把评估指标改动一下就行。回归输出的是损失曲线、R^2曲线、训练集预测值与真实值折线图、测试集预测值散点图与真实值折线图。输出效果如下&#xff1a; 注意&#xff1a;预测值与真实值图像处理为按真实值排序&#xff0c;图中呈现…

OCR识别行驶证(阿里云和百度云)

OCR识别行驶证(阿里云和百度云) 一、使用场景 1、通过识别行驶证&#xff0c;获取相关汽车信息&#xff0c;替代手输 二、效果图 三、代码部分&#xff1a; 1、阿里云OCR 1.1、控制层 PostMapping("/ocrCard") public JSONObject ocrCard(RequestPart("fi…

快速入门:使用Python构建学生成绩管理应用

前言 诸位观众&#xff0c;本学期我有幸学习了Python编程课程。随着课程的结束&#xff0c;授课教师布置了一项任务&#xff0c;要求我们开发一个学生信息管理系统。基于老师的要求&#xff0c;我个人独立完成了这项任务。今天&#xff0c;我希望将这个简易的程序分享给大家&a…

【数字三角形】

题目 代码 #include <bits/stdc.h> using namespace std;const int N 510; int f[N][N]; int a[N][N]; int main() {int n;cin >> n;for(int i 1; i < n; i){for(int j 1; j < i; j){cin >> a[i][j];if(i 1 && j 1) f[i][j] a[i][j];el…

ORCAD Capture CIS 打开原理图总是卡住

原因&#xff1a;ORCAD自动进行了DRC检查。要打开的原理图中footprint未指定footprint路径。 修改&#xff1a;1、第一种方法&#xff1a;指定footprint路径 2、第二种方法&#xff1a;关闭在线DRC检查

钢包智慧管理平台

钢包智慧管理平台基于海康、大华视频监控&#xff0c;实现对钢包的全动态管理&#xff0c;实时检测钢包的温度数据变化&#xff0c;也可以随时查询时间区间内的钢包温度数据变化。 平台基于springboot vue前后台分离技术开发&#xff0c;视频基于zlmedia的转码拉流。实现了视频…

STM32————SPI硬件外设实现读写

首先是理论知识&#xff1a; 常用8位数据帧、高位先行 SPI的时钟由PCLK内部时钟分频得来&#xff0c;最大可到36MHz 精简为半双工就是去掉一根数据线后&#xff0c;用剩下的一根作为发送/接收数据&#xff1b;单工就是去掉接收线&#xff0c;只用发送线进行发送数据&#xf…

揭秘CAAC、AOPA、ALPA、ASFC和UTC无人机执照的差别及实用价值

CAAC、AOPA、ALPA、ASFC和UTC无人机执照各有其独特的差别及实用价值&#xff0c;以下是针对这些执照的详细解析&#xff1a; 一、CAAC无人机执照 颁发机构&#xff1a;中国民用航空局&#xff08;CAAC&#xff09; 差别&#xff1a; - 权威性&#xff1a;CAAC无人机执照是目…

Java面试题--JVM大厂篇之JVM 大厂面试题及答案解析(2)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到我的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而我的博客&…

Leetcode 1108. IP地址无效化

Leetcode 1108. IP 地址无效化 问题&#xff1a;给你一个有效的 IPv4 地址address&#xff0c;返回这个 IP 地址的无效化版本。 所谓无效化 IP 地址&#xff0c;其实就是用 "[.]" 代替了每个 "."。 方法1&#xff1a;对字符串挨个进行判断&#xff0c;如…

http连接未释放导致生产故障

凌晨4点运维老大收到NAT网关连接数打满报警&#xff08;官网页面接口超时&#xff09;&#xff0c;运维自己先看了看服务器相关配置&#xff0c;先后还联系了阿里云的客服&#xff0c;客服建议升级NAT网络连接阈值&#xff0c;之前是1w升级到了5w&#xff0c;但后来还是给研发打…

安装torchvision==0.5.0

安装pytorch 1.4 但是在当前配置的镜像源中找不到 torchvision0.5.0 这个版本的包。 直接找资源下载 网址添加链接描述 直接运行该命令&#xff0c;成功。 然后重复运行上面的命令就可以了 # CUDA 9.2 conda install pytorch1.4.0 torchvision0.5.0 cudatoolkit9.2 -c pyto…

Python编码系列—Python单元测试的艺术:深入探索unittest与pytest

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

CS1.5快捷键

《黑神话悟空》玩不起&#xff0c;玩起了23年前的cs1.5 B11&#xff1a;USP(警察自带手枪&#xff09; B12&#xff1a;Glock18(匪徒自带手枪) B13&#xff1a;Desert Eagle&#xff08;沙漠之鹰&#xff09; B14&#xff1a;P-228 B15&#xff1a;Dual Berettas&#xff08;匪…