C++ 标准库容器的常用成员函数

ops/2025/3/4 20:19:24/

目录

C++ 标准库容器简介

通用成员函数

1. 大小相关

size()

empty()

max_size()

2. 元素访问

operator[]

at(size_t n)

front()

back()

3. 修改容器

push_back(const T& value)

pop_back()

clear()

insert()

erase()

4. 迭代器相关

begin()

end()

rbegin() 和 rend()

std::vector 的特有成员函数 

1. capacity()

2. reserve(size_t n)

3. resize(size_t n)

4. shrink_to_fit()(C++11 起)

其他容器的特有函数(简单介绍)

std::list:

std::map:

std::set:

C++ 标准库提供了多种容器(如 std::vector、std::list、std::map 等),这些容器都有一些通用的成员函数,也有一些特定于容器类型的函数。

C++ 标准库容器简介

C++ 标准库容器在 <vector>、<list>、<map> 等头文件中定义,属于 STL(标准模板库)的一部分。常见的容器包括:

  • 顺序容器:std::vector(动态数组)、std::array(固定数组)、std::list(双向链表)、std::deque(双端队列)。

  • 关联容器:std::map(键值对映射)、std::set(唯一键集合)。

  • 无序容器:std::unordered_map、std::unordered_set(哈希表实现)。

每个容器都有一套成员函数,用于操作容器中的元素、管理大小和访问数据。

通用成员函数

大多数容器都支持以下通用成员函数(部分可能因容器类型略有差异):

1. 大小相关

  • size()
    • 返回容器当前元素个数。

    • 返回类型:size_t(无符号整数)。

    • 示例:

std::vector<int> vec = {1, 2, 3};
std::cout << vec.size();  // 输出 3
empty()
  • 检查容器是否为空。

  • 返回类型:bool(true 表示空)。

  • 示例:

std::vector<int> vec;
std::cout << vec.empty();  // 输出 1 (true)
vec.push_back(1);
std::cout << vec.empty();  // 输出 0 (false)
max_size()
  • 返回容器理论上能容纳的最大元素个数(受内存限制)。

  • 返回类型:size_t。

  • 示例:

std::vector<int> vec;
std::cout << vec.max_size();  // 输出很大数字(如 2³²-1 或 2⁶⁴-1)

2. 元素访问

  • operator[]
    • 通过索引访问元素(不检查越界)。

    • 返回类型:元素类型的引用(T&)。

    • 只适用于支持随机访问的容器(如 vector, deque)。

    • 示例:

std::vector<int> vec = {10, 20, 30};
std::cout << vec[1];  // 输出 20
vec[1] = 50;          // 修改为 50
at(size_t n)
  • 通过索引访问元素(带越界检查,抛出 std::out_of_range 异常)。

  • 返回类型:元素类型的引用(T&)。

  • 示例:
std::vector<int> vec = {10, 20};
std::cout << vec.at(1);  // 输出 20
// vec.at(5);  // 抛出异常:out of range
front()
  • 返回第一个元素的引用。

  • 示例:

std::vector<int> vec = {1, 2, 3};
std::cout << vec.front();  // 输出 1
back()
  • 返回最后一个元素的引用。

  • 示例:

std::vector<int> vec = {1, 2, 3};
std::cout << vec.back();  // 输出 3

3. 修改容器

  • push_back(const T& value)
    • 在容器末尾添加一个元素(vector, list, deque 支持)。

    • 示例:

std::vector<int> vec;
vec.push_back(42);  // vec = {42}
pop_back()
  • 删除最后一个元素(不返回)。

  • 示例:

std::vector<int> vec = {1, 2, 3};
vec.pop_back();  // vec = {1, 2}
clear()
  • 删除所有元素,使容器变空。

  • 示例:

std::vector<int> vec = {1, 2, 3};
vec.clear();  // vec 变空,size() == 0
insert()
  • 在指定位置插入元素(具体参数因容器不同)。

  • 示例(vector):

std::vector<int> vec = {1, 3};
vec.insert(vec.begin() + 1, 2);  // vec = {1, 2, 3}
erase()
  • 删除指定位置或范围的元素。

  • 示例:

std::vector<int> vec = {1, 2, 3};
vec.erase(vec.begin());  // vec = {2, 3}

4. 迭代器相关

  • begin()
    • 返回指向第一个元素的迭代器。

    • 示例:

std::vector<int> vec = {1, 2, 3};
auto it = vec.begin();  // it 指向 1
end()
  • 返回指向末尾后一位置的迭代器(不指向最后一个元素)。

  • 示例:

std::vector<int> vec = {1, 2, 3};
auto it = vec.end();  // 指向 3 之后的“哨兵”位置
rbegin() 和 rend()
  • 返回反向迭代器(从末尾向开头遍历)。

  • 示例:

std::vector<int> vec = {1, 2, 3};
auto rit = vec.rbegin();  // 指向 3

std::vector 的特有成员函数 

1. capacity()
  • 返回当前分配的内存容量(可能大于 size())。

  • 示例:

std::vector<int> vec;
vec.push_back(1);
std::cout << vec.capacity();  // 可能输出 1、2、4(实现依赖)
2. reserve(size_t n)
  • 预分配内存空间,避免频繁扩展。

  • 示例:

std::vector<int> vec;
vec.reserve(10);  // 预留空间给 10 个元素
vec.push_back(1);  // 不会重新分配内存
3. resize(size_t n)
  • 调整容器大小,多余元素删除,缺少元素用默认值填充。

  • 示例:

std::vector<int> vec = {1, 2};
vec.resize(4);  // vec = {1, 2, 0, 0}
vec.resize(1);  // vec = {1}
4. shrink_to_fit()(C++11 起)
  • 缩小容量以匹配当前大小(非强制,可能无效)。

  • 示例:

std::vector<int> vec(100);  // 容量 >= 100
vec.resize(10);
vec.shrink_to_fit();  // 试图将容量缩小到 10

其他容器的特有函数(简单介绍)

  • std::list:
    • push_front():在头部添加元素。

    • pop_front():删除头部元素。

  • std::map:
    • find(key):查找键对应的元素。

    • insert({key, value}):插入键值对。

  • std::set:
    • count(value):检查值是否存在(返回 0 或 1)。


http://www.ppmy.cn/ops/162764.html

相关文章

Python----数据分析(Numpy:安装,数组创建,切片和索引,数组的属性,数据类型,数组形状,数组的运算,基本函数)

一、 Numpy库简介 1.1、概念 NumPy(Numerical Python)是一个开源的Python科学计算库&#xff0c;旨在为Python提供 高性能的多维数组对象和一系列工具。NumPy数组是Python数据分析的基础&#xff0c;许多 其他的数据处理库&#xff08;如Pandas、SciPy&#xff09;都依赖于Num…

git基本用法

原理图&#xff1a; 显示工作目录和暂存区的状态。 git status 三种状态&#xff1a;已提交&#xff08;committed&#xff09;、已修改&#xff08;modified&#xff09; 和 已暂存&#xff08;staged&#xff09; 配置 git config --global user.name "Your Name&qu…

NC2227_约瑟夫环

题解: import java.util.Scanner;​public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int k sc.nextInt();int m sc.nextInt();int set 0;for(int i 2;i < n;i ){set (set m) % i;}System.out.p…

基于Flask实现的多语言Hello World

简介 在这篇文章中&#xff0c;我们将探讨如何使用Flask框架创建一个智能的多语言Hello World服务器。这个服务器能够自动检测访问者的浏览器语言设置&#xff0c;并返回相应语言版本的"Hello World"问候语&#xff0c;支持超过20种世界主要语言。 技术栈 Python …

【linux】详谈 环境变量

目录 一、基本概念 二、常见的环境变量 取消环境变量 三、获取环境变量 通过代码获取环境变量 环境变量的特性 1. getenv函数:获取指定的环境变量 2. environ获取环境变量 四、本地变量 五、定义环境变量的方法 临时定义&#xff08;仅对当前会话有效&#xff09; 永…

DeepSeek 1.5B蒸馏模型的J6部署(Llama方式)

前言 DeepSeek 是一款基于人工智能的搜索引擎&#xff0c;旨在提升用户的搜索体验。它利用先进的自然语言处理技术&#xff0c;通过理解查询的上下文和意图&#xff0c;为用户提供更精确、相关的搜索结果。与传统的搜索引擎不同&#xff0c;DeepSeek 不仅仅依赖于关键词匹配&a…

【Python】基础语法三

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;了解Python的函数、列表和数组。 > 毒鸡汤&#xff1a;有些事情&#xff0c;总是不明白&#xff0c;所以我不会坚持。早安! > 专栏选自&#xff…

接口性能优化?

目录 接口性能优化方法和具体案例 接口性能优化方法 接口性能优化的具体案例 接口性能优化 接口性能优化方法和具体案例 接口性能优化方法 数据库操作优化 减少操作次数:尽量采用批量操作,避免在循环中执行单个数据库操作,如使用 MyBatis 的<foreach>标签实现批量…