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

c++ std::vector使用笔记

std::vector 是 C++ 标准库中的一个动态数组容器,提供了丰富的接口来管理容量、插入、删除和访问元素。以下是对你提到的接口的详细说明和使用示例:

1. 容量相关接口

  • capacity(): 返回当前 vector 分配的存储空间大小(以元素数量计),即在不重新分配内存的情况下可以容纳的元素数量。

    std::vector<int> vec;
    vec.reserve(100);  // 预留 100 个元素的空间
    std::cout << "Capacity: " << vec.capacity() << std::endl;  // 输出: Capacity: 100
    
  • reserve(size_type n): 预留至少能容纳 n 个元素的内存空间。如果 n 大于当前容量,vector 会重新分配内存以增加容量。

    std::vector<int> vec;
    vec.reserve(100);  // 预留 100 个元素的空间
    
  • shrink_to_fit(): 请求移除未使用的容量,使 capacity() 等于 size()。这个请求是非强制的,具体实现可能会忽略。

    std::vector<int> vec(100);
    vec.resize(10);  // 缩小 size 到 10
    vec.shrink_to_fit();  // 请求缩小容量
    std::cout << "Capacity after shrink: " << vec.capacity() << std::endl;  // 输出: Capacity after shrink: 10
    

2. 附加元素接口

  • push_back(const T& value): 在 vector 的末尾添加一个元素。

    std::vector<int> vec;
    vec.push_back(10);  // vec: [10]
    vec.push_back(20);  // vec: [10, 20]
    
  • emplace_back(Args&&... args): 在 vector 的末尾就地构造一个元素,避免了不必要的拷贝或移动操作。

    std::vector<std::string> vec;
    vec.emplace_back("Hello");  // vec: ["Hello"]
    vec.emplace_back("World");  // vec: ["Hello", "World"]
    

3. 元素插入接口

  • insert(iterator pos, const T& value): 在指定位置 pos 前插入一个元素。

    std::vector<int> vec = {1, 3};
    vec.insert(vec.begin() + 1, 2);  // vec: [1, 2, 3]
    
  • emplace(iterator pos, Args&&... args): 在指定位置 pos 前就地构造一个元素。

    std::vector<std::string> vec = {"Hello", "World"};
    vec.emplace(vec.begin() + 1, "C++");  // vec: ["Hello", "C++", "World"]
    

4. 元素删除接口

  • pop_back(): 删除 vector 的最后一个元素。

    std::vector<int> vec = {1, 2, 3};
    vec.pop_back();  // vec: [1, 2]
    
  • erase(iterator pos): 删除指定位置 pos 的元素。

    std::vector<int> vec = {1, 2, 3};
    vec.erase(vec.begin() + 1);  // vec: [1, 3]
    
  • erase(iterator first, iterator last): 删除范围 [first, last) 内的元素。

    std::vector<int> vec = {1, 2, 3, 4};
    vec.erase(vec.begin() + 1, vec.begin() + 3);  // vec: [1, 4]
    
  • clear(): 清空 vector 中的所有元素。

    std::vector<int> vec = {1, 2, 3};
    vec.clear();  // vec: []
    

5. 元素访问接口

  • operator[]: 通过下标访问元素,不进行边界检查。

    std::vector<int> vec = {1, 2, 3};
    int x = vec[1];  // x = 2
    
  • at(size_type pos): 通过下标访问元素,进行边界检查,如果 pos 超出范围则抛出 std::out_of_range 异常。

    std::vector<int> vec = {1, 2, 3};
    int x = vec.at(1);  // x = 2
    
  • front(): 返回 vector 的第一个元素。

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

    std::vector<int> vec = {1, 2, 3};
    int x = vec.back();  // x = 3
    
  • data(): 返回指向 vector 内部数组的指针。

    std::vector<int> vec = {1, 2, 3};
    int* p = vec.data();  // p 指向 vec 的内部数组
    

6. 容量相关

  • empty(): 判断 vector 是否为空。

    std::vector<int> vec;
    if (vec.empty()) {
        std::cout << "Vector is empty" << std::endl;
    }
    
  • size(): 返回 vector 中当前元素的数量。

    std::vector<int> vec = {1, 2, 3};
    std::cout << "Size: " << vec.size() << std::endl;  // 输出: Size: 3
    
  • max_size(): 返回 vector 可以容纳的最大元素数量。

    std::vector<int> vec;
    std::cout << "Max size: " << vec.max_size() << std::endl;
    

总结

std::vector 提供了丰富的接口来管理动态数组的容量、插入、删除和访问元素。合理使用这些接口可以有效地管理内存并提高代码的性能。

相关文章:

  • 【联盛德 W803-Pico 试用】简介、工程测试
  • 安装可视化jar包部署平台JarManage
  • 【算法系列】leetcode1419 数青蛙 --模拟
  • ROS2下编写package利用orbbec相机进行yolov8实时目标检测
  • iOS端集成人脸识别功能、人证合一、JavaScript接口集成
  • ChatGPT超级AI对话模型 黑客十问十答
  • Hadoop-HA集群部署
  • AI刷题-多零件流水线优化问题
  • vue 判断一个属性值,如果是null或者空字符串或者是空格没有值的情况下,赋值为--
  • 【并发压测】高并发下Linux流量监控
  • TensorFlow 概念
  • 第五章 起航12 实习的小鸽飞了
  • 【RK3588嵌入式图形编程】-SDL2-构建模块化UI
  • istio介绍补充以及使用篇
  • 美团MTSQL特性解析:技术深度与应用广度的完美结合
  • Jmeter进阶篇(34)如何解决jmeter.save.saveservice.timestamp_format=ms报错?
  • 对学习编程语言的一些理解
  • Linux:文件(二)
  • flutter将utf-8编码的字节序列转换为中英文字符串
  • STL —— 洛谷字符串(string库)入门题(蓝桥杯题目训练)(二)
  • 上海交大曾小勤:科技传播不应停留于知识搬运,要做科学思维的播种机
  • 多少Moreless:向世界展示现代中式家具的生活美学
  • 国家卫健委通报:吊销肖某医师执业证书,撤销董某莹四项证书
  • 南京江宁区市监局通报:盒马一批次猕猴桃检出膨大剂超标
  • 人民网三评“网络烂梗”:莫让低级趣味围猎青少年
  • 诠释微末处的丰盈:“上海制造佳品汇”首届海外专场即将亮相日本大阪