【C++之容器篇】精华:vector常见函数的接口的熟悉与使用
创始人
2024-05-25 08:27:48
0

目录

    • 前言
    • 一、认识vector
      • 1. 介绍
      • 2. 成员类型
    • 二、默认成员函数(Member functions)
      • 1. 构造函数
      • 2. 拷贝构造函数
        • vector (const vector& x);
      • 3. 析构函数
      • 4. 赋值运算符重载函数
    • 三、迭代器(Iterators)
      • 1. 普通对象的迭代器
      • 2. const对象的迭代器
      • 3. 普通对象的反向迭代器
      • 4. const对象的反向迭代器
    • 四、容量接口(Capacity)
      • 1. size()
      • 2. capacity()
      • 3. reserve()
      • 4. resize()
    • 五、元素访问接口(Element access)
      • 1. operator[]
        • (1)reference operator[](size_t n)
        • (2)const reference operator[](size_t n)const
      • 2. at()
        • (1)reference at() const
        • (2)const reference at(size_t n) const
      • 3. front()
      • 4.back()
    • 六、修改接口(Modifiers)
      • 1. push_back()
      • 2. pop_back()

前言

前面我们在学习C语言版本的数据结构时,学习过SeqList顺序表的实现,C语言实现的顺序表存在一定的局限性,一次性只能支持存储一种类型的数据,今天我们将学习C++标准库中一种新的顺序表:vector的使用

一、认识vector

1. 介绍

vector是一个支持动态扩容的数组,并且是以模板进行支持的,所以可以实现存储不同类型的数据,实用性比较广。
在这里插入图片描述

2. 成员类型

在这里插入图片描述

二、默认成员函数(Member functions)

1. 构造函数

在这里插入图片描述
标准库中的vector支持了很多版本的构造函数,但是在实际的使用过程中比较常用的是无参的构造函数。

  • 代码1:无参构造函数
int main()
{vector v1;vector v2;vector v3;return 0;
}

调试结果:
在这里插入图片描述

  • 代码2:使用n个数据进行构造
int main()
{vector v1(6, 8);vector v2(5, 6.6);vector v3(6, "hello std::vector");return 0;
}

调试结果:
在这里插入图片描述

  • 代码3:使用一个迭代器区间进行构造
int main()
{string s("hello std::vector::vector(iterator begin,iterator end)");vector v(s.begin(), s.end());for (auto e : v){cout << e << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

2. 拷贝构造函数

vector (const vector& x);

vector的拷贝构造函数需要实现成深拷贝,其用法和其他类基本类似

  • 代码:
int main()
{string s("hello std::vector::vector(iterator begin,iterator end)");vector v(s.begin(), s.end());vector v1(v);for (auto e : v){cout << e << " ";}cout << endl;for (auto e : v1){cout << e << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

3. 析构函数

vector中有动态申请的资源,所以需要手动实现析构函数在函数生命周期结束时自动调用该析构函数完成资源的释放。

4. 赋值运算符重载函数

在这里插入图片描述

赋值运算符重载函数需要实现的也是深拷贝,下面介绍其用法:

  • 代码:
int main()
{string s("hello std::vector(const vector&v)");vector v1(s.begin(),s.end());vector v2;v2 = v1;cout << "v1:" << endl;for (auto ch : v1){cout << ch << " ";}cout << endl;cout << "v2:" << endl;for (auto ch : v2){cout << ch << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

三、迭代器(Iterators)

1. 普通对象的迭代器

普通对象一般调用的就是普通的迭代器,迭代器的一个很重要的作用就是遍历数组,同时范围for的底层原理就是迭代器

  • 代码1:遍历
int main()
{string s("hello std::vector::iterator begin() and end()");vector v(s.begin(), s.end());vector::iterator vit = v.begin();while (vit != v.end()){cout << *vit << " ";vit++;}cout << endl;for (auto& ch : v){cout << ch << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

  • 代码2:支持修改
int main()
{string s("hello std::vector::iterator begin() and end()");vector v(s.begin(), s.end());vector::iterator vit = v.begin();while (vit != v.end()){(*vit) += 1;cout << *vit << " ";vit++;}cout << endl;for (auto& ch : v){cout << ch << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

2. const对象的迭代器

const类型的对象调用const版本的迭代器,不支持修改,支持遍历容器

  • 代码:
int main()
{string s("hello std::vector::const_iterator begin() and end()");const vector v(s.begin(), s.end());vector::const_iterator vit = v.begin();while (vit != v.end()){cout << *vit << " ";vit++;}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

  • 代码2:不支持修改
    在这里插入图片描述

3. 普通对象的反向迭代器

  • 代码:
int main()
{string s("hello std::vector::iterator rbegin() and rend()");vector v(s.begin(), s.end());vector::reverse_iterator vit = v.rbegin();while (vit != v.rend()){cout << *vit << " ";vit++;}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

4. const对象的反向迭代器

  • 代码:
int main()
{string s("hello std::vector::const_reverse_iiterator rbegin() and rend()");const vector v(s.begin(), s.end());vector::const_reverse_iterator vit = v.rbegin();while (vit != v.rend()){cout << *vit << " ";vit++;}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

四、容量接口(Capacity)

1. size()

在这里插入图片描述

  • 代码:
int main()
{string s("hello std::vector::size()");vector v(s.begin(),s.end());cout << "size:" << v.size() << endl;return 0;
}

运行结果:
在这里插入图片描述

2. capacity()

在这里插入图片描述

  • 代码:
int main()
{string s("hello std::vector::capacity()");vector v(s.begin(), s.end());cout << "capacity:" << v.capacity() << endl;return 0;
}

运行结果:
在这里插入图片描述

3. reserve()

在这里插入图片描述

  • 代码:
int main()
{string s("hello std::vector::reserve()");vector v(s.begin(), s.end());cout << "capacity:" << v.capacity() << endl;v.reserve(100);cout << "capacity:" << v.capacity() << endl;return 0;
}

运行结果:
在这里插入图片描述

4. resize()

在这里插入图片描述

  • 代码1:
int main()
{string s("hello std::vector::resize()");vector v(s.begin(),s.end());cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;v.resize(100, 'x');cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;return 0;
}

运行结果:
在这里插入图片描述

  • 代码2:
int main()
{string s("hello std::vector::resize()");vector v(s.begin(), s.end());v.reserve(50);cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;v.resize(46, 'x');cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;return 0;
}

运行结果:
在这里插入图片描述

  • 代码3:
int main()
{string s("hello std::vector::resize()");vector v(s.begin(), s.end());v.reserve(50);cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;v.resize(23, 'x');cout << "size:" << v.size() << endl;cout << "capacity:" << v.capacity() << endl;return 0;
}

运行结果:
在这里插入图片描述

五、元素访问接口(Element access)

1. operator[]

在这里插入图片描述

(1)reference operator[](size_t n)

  • 代码:
int main()
{string s("hello std::vector::reference operator[](size_t n)");vector v(s.begin(), s.end());for (size_t i = 0; i < v.size(); i++){cout << v[i] << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

(2)const reference operator[](size_t n)const

  • 代码:
int main()
{string s("hello std::vector::const reference operator[](size_t n)");const vector v(s.begin(), s.end());for (size_t i = 0; i < v.size(); i++){cout << v[i] << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

2. at()

在这里插入图片描述

(1)reference at() const

  • 代码:
int main()
{string s("hello std::vector::reference at(size_t n)");vector v(s.begin(), s.end());for (size_t i = 0; i < v.size(); i++){cout << v.at(i) << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

(2)const reference at(size_t n) const

  • 代码:
int main()
{string s("hello std::vector::const reference at(size_t n) const");const vector v(s.begin(), s.end());for (size_t i = 0; i < v.size(); i++){cout << v.at(i) << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

3. front()

在这里插入图片描述

  • 代码:

int main()
{string s("hello std::vector::front()");vector v(s.begin(), s.end());cout << v.front() << endl;return 0;
}

运行结果:
在这里插入图片描述

4.back()

在这里插入图片描述

  • 代码:
int main()
{string s("hello std::vector::back()");vector v(s.begin(), s.end());cout << v.back() << endl;return 0;
}

运行结果:
在这里插入图片描述

六、修改接口(Modifiers)

1. push_back()

在这里插入图片描述

  • 代码:
int main()
{vector v;v.push_back(1);v.push_back(2);v.push_back(3);v.push_back(4);v.push_back(5);v.push_back(6);vector::iterator vit = v.begin();while (vit != v.end()){cout << *vit << " ";vit++;}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

2. pop_back()

在这里插入图片描述

  • 代码:
int main()
{string s("hello std::vector pop_back()");vector v(s.begin(), s.end());vector::iterator vit = v.begin();while (vit != v.end()){cout << *vit << " ";vit++;}cout << endl;v.pop_back();v.pop_back();for (auto& ch : v){cout << ch << " ";}cout << endl;return 0;
}

运行结果:
在这里插入图片描述

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...