序列容器

news/2024/9/18 3:55:16/文章来源:https://www.cnblogs.com/sprinining/p/18368702

序列容器

序列容器以线性序列的方式存储元素。它没有对元素进行排序,元素的顺序和存储它们的顺序相同。5 种标准的序列容器,每种容器都具有不同的特性:

  1. array<T,N> (数组容器) :长度固定的序列,有 N 个 T 类型的对象,不能增加或删除元素。
  2. vector<T> (向量容器) :长度可变的序列,用来存放T类型的对象。必要时,可以自动增加容量,但只能在序列的末尾高效地增加或删除元素。
  3. deque<T> (双向队列容器) :长度可变的、可以自动增长的序列,在序列的两端都不能高效地增加或删除元素。
  4. list<T> (链表容器) 长度可变的、由 T 类型对象组成的序列,它以双向链表的形式组织元素,在这个序列的任何地方都可以高效地增加或删除元素。访问容器中任意元素的速度要比前三种容器慢,这是因为 list<T> 必须从第一个元素或最后一个元素开始访问,需要沿着链表移动,直到到达想要的元素。
  5. forward list<T> (正向链表容器) :是一个长度可变的、由 T 类型对象组成的序列,它以单链表的形式组织元素,是一类比链表容器快、更节省内存的容器,但是它内部的元素只能从第一个元素开始访问。

容器中常见的函数成员

array、vector 和 deque 容器的函数成员

函数成员 array<T,N> vector deque
begin() - 返回幵始迭代器
end() - 返回结束迭代器
rbegin() - 返回反向开始迭代器
rend() - 返回反向结束迭代器
cbegin() - 返M const开始迭代器
cend() - 返回const结束迭代器
crbegin() - 返回const反向开始迭代器
crend() - 返回const反向结束迭代器
assign() - 用新元素替换原有内容 -
operator=() - 复制同类型容器的元素,或者用初始化列表替换 现有内容
size() - 返回实际元素个数
max_size() - 返回元素个数的设大值
capacity() - 返回当前容量 - -
empty() - 返回true,如果容器中没有元素的话
resize() - 改变实际元素的个数 -
shrink _to_fit() - 将内存减少到等于当前元素实际所使用的大小 -
front() - 返回第一个元素的引用
back() - 返回铖后一个元素的引用
operator[]() - 使用索弓丨访问元素
at() - 使用经过边界检査的索引访问元素
push_back() - 在序列的尾部添加一个元素 -
insert() - 在指定的位置插入一个或多个元素 -
emplace() - 在指定的位置直接生成一个元素 -
emplace_back() - 在序列尾部生成一个元素 -
pop_back() - 移出序列尾部的元素 -
erase() - 移出一个元素或一段元素 -
clear() - 移出所苻的元素,容器大小变为 0 -
swap() - 交换两个容器的所有元素
data() - 返回包含元素的内部数组的指针 -

list 和 forward_list 的函数成员

函数成员 list forward list
begin() - 返回开始迭代器
end() - 返回结束迭代器
rbegin() - 返回反向开始迭代器 -
rend() - 返回反向结束迭代器 -
cbegin() - 返回 const 开始结束迭代器
before_begin() - 返回一个指向第一个元素前一个位置的迭代器 -
cbefore_begin() - 返回一个指向第一个元素前一个位置的const迭代器 -
cend() - 返回 const 结束迭代器
crbegin() - 返回 const 反向开始迭代器 -
crend() - 返回 const 反向结束迭代器 -
assign() - 用新元素替换原有内容
operator=() - 复制同类型容器的元素,或者用初始化列表替换现有内容
size() - 返回实际元素个数 -
max_size() - 返回元素个数的最大值
resize() - 改变实际元素的个数
empty() - 返回 true,如果容器中没有元素的话
from() - 返回第一个元素的引用
back() - 返回最后一个元素的引用 -
push_back() - 在序列的潘部添加一个元素 -
push_front() - 在序列的起始位置添加一个元素
emplace() - 在指矩位置直接生成一个元素 -
emplace_after() - 在指定位置的后面直接生成一个元素 -
emplace_back() - 在序列尾部生成一个元素 -
cmplacc_front() - 在序列的起始位生成一个元索
insert() - 在指定的位置插入一个或多个元素 -
insert_after() - 在指定位置的后面插入一个或多个元素 -
pop_back() - 移除序列尾部的元素 -
pop_front() - 移除序列头部的元素
reverse()-反向元素的顺序
erase() - 移除指定位置的一个元素或一段元素 -
erase_after() - 移除指定位 1;后面的一个元素或一段元素 -
remove() - 移除所苻和参数匹配的元素
remove_if() - 移除满足一元函数条件的所有元素
unique() - 移除所有连续重复的元素
clear() - 移除所有的元素,容器大小变为 0
swap() - 交换两个容器的所有元素
sort() - 对元素进行排序
merge() - 合并两个有序容器
splice() - 移动指定位置前面的所有元素到另一个同类型的 list 中 -
splice_after() - 移动指定位置后面的所有元素到另一个同类型的 list 中 -

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

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

相关文章

Antd-React-TreeSelect前端搜索过滤

Antd-React-TreeSelect前端搜索过滤,antd本事是带有搜索的功能,但是在开发过程中发现自带的搜索功能与我们要使用的搜索过滤还是差了好多,在一些时候搜索为了迎合需要不得不这么操作,那么该操作结合了antd官方的搜索操作,因而在看了网上的一些操作后还是与需求不符合,最后…

方法的三种调用形式

在《可以调用Null的实例方法吗?》一文中,我谈到.NET方法的三种调用形式,现在我们就来着重聊聊这个话题。具体来说,这里所谓的三种方法调用形式对应着三种IL指令:Call、CallVirt和Calli。在《可以调用Null的实例方法吗?》一文中,我谈到.NET方法的三种调用形式,现在我们就…

关于隐藏Selenium绕过检测

. 浏览器指纹识别:网站通常通过浏览器指纹识别来检测访问者的身份。浏览器指纹是浏览器在访问网站时提供的一组信息,包括浏览器类型、版本、插件、用户代理字符串、屏幕分辨率、语言设置、操作系统等。 当你使用 Selenium 或其他自动化工具时,某些指纹信息可能会暴露自动化工…

依赖倒置原则

一、前言 依赖倒置原则也称依赖倒转原则(Dependence Inversion Principle) 看官方定义 高层模块不应该依赖底层模块,二者都应该依赖其抽象 抽象不应该依赖细节,细节应该依赖抽象 依赖倒置的中心思想是面向接口编程 如果你了解点设计模式,应该理解上面的话,但是如果不了解…

常见温升测试方法

常见温升测试方法 温升测试是电器产品安规测试项目之一,是为了检测电器产品及部件的温度变化情况,判断是否符合要求。在设备运行过程中会释放一定的热量,如果内部温度过高会影响产品的性能和稳定性,导致绝缘性能下降,因此温升测试是确保产品稳定运行的重要步骤。那么如何进…

当代码遇上诈骗,开发者该何去何从?

大家好,我是晓凡。 不知道大家最近有没有刷到这样一则消息:知名开源工具 Aria 的开发者删库跑路。 是的,你没听错,这不是段子,这是真事儿! 一言不合就删库? 这事儿得从一条令人震惊的提交记录说起。开发者留下的话,简直比冬天的北风还要刺骨:“因为自己的开源项目被诈…

5 个有趣的 Python 开源项目「GitHub 热点速览」

本期,我从上周的开源热搜项目中精心挑选了 5 个有趣、好玩的 Python 开源项目。 首先是 PyScript,它可以让你直接在浏览器中运行 Python 代码,不仅支持在 HTML 中嵌入,还能安装第三方库。然后是用 Python 写的“魔法虫洞” magic-wormhole,这是一个无需服务器、通过一条命…

耗时9个月,1.34万行代码,这套分布式微服务架构项目,完结啦!

作者:小傅哥 博客:https://bugstack.cn沉淀、分享、成长,让自己和他人都能有所收获!😄大家好,我是技术UP主小傅哥。 耗时9个月,1.34万行代码,55节课程,全程视频手把手。这套微服务、分布式、DDD架构,涵盖了;抽奖、活动、积分、兑换,运用了分库分表、binlog同步数据…

JetBrains PhpStorm 2024.2 (macOS, Linux, Windows) - 高效智能的 PHP IDE

JetBrains PhpStorm 2024.2 (macOS, Linux, Windows) - 高效智能的 PHP IDEJetBrains PhpStorm 2024.2 (macOS, Linux, Windows) - 高效智能的 PHP IDE JetBrains 跨平台开发者工具 请访问原文链接:https://sysin.org/blog/jetbrains-phpstorm/,查看最新版。原创作品,转载请…

Viper:强大的Go配置解析库

1 介绍 Viper是适用于Go应用程序的完整配置解决方案。它被设计用于在应用程序中工作,并且可以处理所有类型的配置需求和格式。目前Star 26.6k, 它支持以下特性:设置默认值 从JSON、TOML、YAML、HCL、envfile和Java properties格式的配置文件读取配置信息 实时监控和重新读取配…

JetBrains GoLand 2024.2 (macOS, Linux, Windows) - 为 Go 开发者打造的完整 IDE

JetBrains GoLand 2024.2 (macOS, Linux, Windows) - 为 Go 开发者打造的完整 IDEJetBrains GoLand 2024.2 (macOS, Linux, Windows) - 为 Go 开发者打造的完整 IDE JetBrains 跨平台开发者工具 请访问原文链接:https://sysin.org/blog/jetbrains-goland/,查看最新版。原创作…

流媒体服务器如何让WebRTC支持H.265,同时又能支持Web Chrome硬解码、软解码:DataChannel+MSE+WASM解码H.265

为了这一整套的解决方案,调研+研发整整花费了差不多半年多的时间,需达成的目标:流媒体服务器端不需要将H.265转码成H.264,就能让Chrome解码播放H.265;注意:现在很多市面上的软硬件通过转码H.265成H.264的方式来支持WebRTC,个人理解,这既费硬件又是技术的倒退!Web JS解…