C++的vector类(一):vector类的常见操作

news2024/9/22 23:30:49

目录

前言

Vector类

遍历与初始化vector

​vector的扩容机制

vector的对象操作

find与insert

对象数组


前言

string类中还有一些内容需要注意:

STL 的string类怎么啦?

C++面试中string类的一种正确写法

C++ STL string的Copy-On-Write技术

C++的std::string的“读时也拷贝”技术!

Vector类

vector文档:cplusplus.com/reference/vector/vector/

基本概念:vector是表示可变数组(针对int、double等,字符数组去用string)的序列容器

类原型:template <class T,class Alloc = allocator<T> >class vector

class Alloc = allocator<T>(内存池)采用系统提供的默认的就行 

注意事项:[]、普通数组和at的区别在于[]利用断言检查不给改错机会,普通数组是抽查的给改错机会,at是异常捕获

以下几个表中的内容与string类中的内容相似,不再一一演示 

vector的定义

(constructor)构造函数声明

接口说明
vector() (重点)
无参构造
vector(size_type n, const value_type& val = value_type())
构造并初始化n个val
vector (const vector& x); (重点)
拷贝构造
vector (InputIterator first, InputIterator last)
使用迭代器进行初始化构造
vector iterator的使用
iterator的使用接口说明

begin +

end

获取第一个数据位置的iterator/const_iterator, 获取最后一个数据的下一个位置 的iterator/const_iterator

rbegin +

rend

获取最后一个数据位置的reverse_iterator,获取第一个数据前一个位置的 reverse_iterator
vector的增删改查
vector的增删改查接口说明

assign

覆盖

push_back

尾插

pop_back

尾删
find查找(不是vector的成员接口,使用时要包含algorithm头文件)

insert

在指定位置前插入数据

erase

删除指定位置数据

swap

交换两个vector的数据空间

clear

清空数据

operator[]

像数组一样访问

遍历与初始化vector

#include <iostream>
#include <vector>
using namespace std;

int main()
{
	//初始化
	vector<int> v;
	v.push_back(1);
	v.push_back(2);
	v.push_back(3);
	v.push_back(4);

    //vector<int>(10,1):开始个空间每个空间给个1

	//[]重载
	for (size_t i = 0; i < v.size(); i++)
	{
		cout << v[i] << "";
	}
	cout << endl;

	//迭代器
	vector<int>::iterator it = v.begin();
	while (it != v.end())
	{
		cout << *it << " ";
		it++;
	}
	cout << endl;

	//范围for
	for (auto i : v)
	{
		cout << i << " ";
	}
		cout << endl;
	return  0;
}

​vector的扩容机制

1、扩容1.5倍然后取整

#include <iostream>
#include <vector>
using namespace std;

void test_vector2()
{
	size_t sz;
	vector<int> v;
	sz = v.capacity();
	cout << "making v grow:\n";
	for (int i = 0; i < 100; i++)
	{
		v.push_back(i);
		if (sz != v.capacity())
		{
			sz = v.capacity();
			cout << "capacity change:" << sz << endl;
		}
	}
}

int main()
{
	test_vector2();
	return  0;
}

2、resize和reserve不会缩容,要缩容用shrink_to_fit

#include <iostream>
#include <vector>
using namespace std;

void test_vector2()
{
	size_t sz;
	vector<int> v;
	sz = v.capacity();
	v.reserve(100);//提前开空间
	cout << "making v grow:\n";
	for (int i = 0; i < 100; i++)
	{
		v.push_back(i);
		if (sz != v.capacity())
		{
			sz = v.capacity();
			cout << "capacity change:" << sz << endl;
		}
	}
	cout << "-----------------------" << endl;

	cout << "reserve尝试对原空间进行缩容 >" << endl;
	cout <<"原size >" << v.size() << endl;
	cout <<"原capacity >" << v.capacity() << endl;

	v.reserve(10);

	cout << "后size >" << v.size() << endl;
	cout << "后capacity >" << v.capacity() << endl;

	cout << "-----------------------" << endl;

	cout << "resize尝试对原空间进行缩容 >" << endl;
	cout << "原size >" << v.size() << endl;
	cout << "原capacity >" << v.capacity() << endl;

	v.resize(10);

	cout << "后size >" << v.size() << endl;
	cout << "后capacity >" << v.capacity() << endl;

	cout << "-----------------------" << endl;

	cout << "原size >" << v.size() << endl;
	cout << "原capacity >" << v.capacity() << endl;
	cout << "shrink_to_fit尝试对原空间进行缩容 >" << endl;

	v.shrink_to_fit();

	cout << "后size >" << v.size() << endl;
	cout << "后capacity >" << v.capacity() << endl;

}

int main()
{
	test_vector2();
	return  0;
}

vector的对象操作

find与insert

#include <iostream>
#include <vector>
#include<string>
#include <algorithm>
using namespace std;

//增删改查
void test_vector3()
{
	vector<int> v;
	v.push_back(1);
	v.push_back(2);
	v.push_back(3);
	v.push_back(4);
	v.push_back(5);

	cout << "初始化 >";
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;


	//找到数组中的3并返回该数据的下标
	auto pos = find(v.begin(), v.end(), 3);
	if (pos != v.end())//左闭右开才能遍历到数组所有的值
	{
		v.insert(pos,30);//在pos位置前插入30
	}
	cout << "在3前插入30后 >";
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;

	//头插
	v.insert(v.begin(), 0);
	cout << "头插0 >";
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;

	//在下标为2的位置插入
	v.insert(v.begin() + 2, 20);
	cout << "在下标为2的位置插入20 >";
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;

	string s("abcd");
	cout << "头插字符串 >";
	v.insert(v.begin(), s.begin(), s.end());
	for (auto e : v)//读取ASCII码
	{
		cout << e << " ";
	}
	cout << endl;

}

int main()
{
	test_vector3();
	return  0;
}

对象数组

push_back的原型:void push_back(const value_type& val)

  • value_type:自适应类型
#include <iostream>
#include <vector>
#include<string>
#include <algorithm>
using namespace std;

//对象数组
void test_vector4()
{
	//对象数组
	vector<string> v;
	//版本一:有名对象
	string s1("苹果");
	v.push_back(s1);

	//版本二:匿名对象
	v.push_back(string("香蕉"));

	//版本三:隐式类型转换->产生临时对象->将该临时对象传入->val就是string类型对象的引用
	//隐式类型转换:字符串->字符数组->调用std::string(const char*)构造临时std::string对象,并将该对象传递给函数
	v.push_back("草莓");//版本一二三效果相同

	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;

}

int main()
{
	test_vector4();
	return  0;
}

        在 Visual Studio 中使用 std::string,通常情况下,当字符串长度小于等于 28 字节时,std::string 对象会将字符串内容存储在对象内部的小缓冲区中。这个小缓冲区被称为 "短字符串优化"。这样可以避免频繁地进行堆分配和释放。对于超过 28 字节的较长字符串,则会动态分配内存来存储其内容,且 std::string 对象本身仅保存指向堆上数据的指针。

        如果有一个包含多个较长字符串的对象数组,并且只关心它们是一个对象数组而不需要了解每个具体元素所在位置或大小细节,那么您可以声明一个 std::vector<std::string> 来存储这些字符串。无论单个 std::string 的大小如何,在该向量中每个元素都将是一个完整的 std:string 对象。

vector是一个数组模板,除了有对象数组,还可以有链表数组、树数组、以及嵌套vector数组:

树数组:vector<tree> tc
链表数组:vector<list> lc
嵌套vector数组:vector<vector<int>> cc

  • 外部vector的T是vector<int>*,内部vector的T是int*
  • vector<int>*可以指向多个vector<int>,int*可以指向多个int
  • 外部vector实例化出了对象数组,内部vector实例化出了整型数组

~over~

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java 继承(上)

在说继承之前&#xff0c;先看Student、Teacher这两个类&#xff0c;通过下面的代码可以看出什么&#xff1f; 细心的你可能已经有所发现了&#xff0c;那就是它们都含有相同的属性和方法。 如果把相同特征提取出来&#xff0c;放到一个类中&#xff0c;暂时先把这个类叫做 Tan…

【Linux】多线程概念 | POSIX线程库

文章目录 一、线程的概念1. 什么是线程Linux下并不存在真正的多线程&#xff0c;而是用进程模拟的&#xff01;Linux没有真正意义上的线程相关的系统调用&#xff01;原生线程库pthread 2. 线程和进程的联系和区别3. 线程的优点4. 线程的缺点5. 线程异常6. 线程用途 二、二级页…

25.删除链表中倒数第N个结点

题意&#xff1a;给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 class Solution { public:ListNode* removeNthFromEnd(ListNode* head, int n) {ListNode* dummyHeadnew ListNode(0); //定义虚拟头结点ListNode* fastdummyHead; //定…

32.网络游戏逆向分析与漏洞攻防-游戏网络通信数据解析-网络数据分析原理与依据

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果 内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;31.其它消息的实…

浅谈游戏地图中位置实时更新的技术方案

地图如今在游戏中发挥的作用越来越重要&#xff0c;随着电子竞技的兴起&#xff0c;地图逐渐成为了为玩家创造体验的直接舞台。希望本文能对有兴趣了解游戏地图背后实现原理的同学一些帮助。 什么是游戏地图 在游戏中可以通过3D场景虚拟一个完整的世界&#xff0c;当3D场景较为…

基于springboot的大学生租房平台系统

技术&#xff1a;springbootmysqlvue 一、系统背景 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对大学生租房信息管理混乱…

C语言每日一题07

一、题目 二、解析 逻辑与 &&、逻辑或 || 均有“短路”特性: 逻辑与&&“短路”&#xff1a;当逻辑与&&的左操作数为逻辑 “假“ 时&#xff0c;就足以判断该逻辑运算的结果为假了&#xff0c;故右操作数就不再被执行。 逻辑或||“短路”&#xff1a…

使用PLCSIM Advanced仿真博途运动控制

作者顾工首先&#xff0c;添加一个CPU&#xff0c;直接添加一个1518T&#xff0c;反正仿真&#xff0c;不用最好的干嘛呢。是吧。当然&#xff0c;你也可以添加一个你喜欢的PLC&#xff0c;这里不强求。 然后添加工艺对象&#xff0c;我们简单添加一个定位轴。 在工艺对象&am…

GPT-5揭秘:Lex Fridman与Sam Altman播客热议,AGI时代的新变革即将来临!

嘿&#xff0c;朋友们&#xff0c;你们知道吗&#xff1f;Lex Fridman和Sam Altman又聚在一起了&#xff0c;这次是在播客上。 在播客中&#xff0c;他们聊了很多&#xff0c;包括董事会的幕后故事、Elon Musk的诉讼案&#xff0c;甚至还提到了Ilya、Sora这些名字。 但真正让…

跟着官方文档一步一步搭建Elastic Stack(3节点ES集群+Kibana+Filebeat+Metricbeat)

文章目录 源码仓库硬件要求配置文件docker-compose.ymlfilebeat.ymlmetricbeat.yml 配置项解读以及注意事项docker-compose.yml解读filebeat配置解读metricbeat配置解读SSL配置ILM配置 运行运行截图 写在最后 本篇文章是使用Filbeat将产品环境的access_lo同步至Elastic Stack中…

SSTI漏洞详解

目录 前备知识 模块引擎&#xff1a; 模块渲染函数&#xff1a; 继承关系&#xff1a; SSTI漏洞简介 SSTI漏洞成因 SSTI漏洞原理 一些常见模块介绍 php Twig模块引擎 代码演示1 Twig模块引擎代码演示2 python flask模块 代码演示1&#xff1a; python jinja模块 代…

Net安卓app BroadcastReceiver 使用记录一坑

1.背景 由于项目需要&#xff0c;需要对接别的app的广播&#xff0c;就看了看Net 安卓开发的广播接收&#xff0c;看官网的介绍单纯广播和接收都挺简单的&#xff0c;于是上手样板项目弄了两个demo出来&#xff0c;app1用来发&#xff0c;app2用来收。 2.版本 &#xff1a;使…

2024格行VS华为VS飞猫哪个是最值得购买随身WiFi?中兴随身WiFi好用吗?

经常出差旅行&#xff0c;或者户外工作的朋友因为长期在外&#xff0c;手机流量经常不够用&#xff0c;想必都是随身WiFi的忠实用户&#xff0c;但是也都被这款产品割韭菜割的头皮发麻。今天&#xff0c;我们统计了市面上最靠谱的、最热销、口碑最好的几款随身WiFi。排名依据来…

查询表中数据(全列/特定列/表达式,where子句(比较/逻辑运算符),order by子句,limit筛选分页),mysql执行顺序

目录 select 全列查询 特定列查询 用表达式查询 (as) 名字 distinct 去重 where子句 比较运算符 列数据之间的比较 ​编辑 别名不能参与比较 null查询 between and in ( ... , ...) 模糊匹配 逻辑运算符 order by子句 可以使用别名 总结mysql执行顺…

【蓝桥杯选拔赛真题71】python判断字符 第十五届青少年组蓝桥杯python选拔赛真题 算法思维真题解析

目录 python判断字符 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、 推荐资料 1、蓝桥杯比赛 2、考级资料 3、其它资料 python判断字符 第十五届蓝桥杯青少年组python比赛选拔赛真题 一、题目要…

Google colab中如何从kaggle中接入数据?

写在前面 使用google colab进行数据分析和探索时&#xff0c;可引用的数据源包括但不限于&#xff1a;1.可上传的数据文件用本地加载的的方式打开数据资源&#xff1b;2.从网络链接中直接打开后加载到缓存中的文件资源&#xff1b;3.通过API或者外部的开放接口加载数据&#x…

软考 网络工程师 每日学习打卡 2024/3/21

学习内容 第8章 网络安全 本章主要讲解网络安全方面的基础知识和应用技术。针对考试应该掌握诸如数据加密、报文认 证、数字签名等基本理论&#xff0c;在此基础上深入理解网络安全协议的工作原理&#xff0c;并能够针对具体的 网络系统设计和实现简单的安全解决方案。 本章共有…

C语言之strsep用法实例(八十六)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

除了Confluence,有没有其他工具一样好用?

每个团队都需要一个协同工作工具&#xff0c;以更有效地管理任务、跟踪进度和分享知识。这就是Atlassian的Confluence发挥作用的地方。然而&#xff0c;尽管它相当强大&#xff0c;其昂贵的价格和复杂的界面可能会让某些用户望而却步。所以&#xff0c;还有其他工具可以替代Con…

面试算法-65-二叉树的层平均值

题目 给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[3.00000,14.50000,11.00000] 解释&#xff1a;第 0 层的…