STL标准库(二)序列容器之vector

发布时间:2024年01月22日

vector 动态数组 本质是向量,一个无限续存的连续内存空间

int main()

{

??? std::vector<int> obj(5); 创建一个容量为5且默认值为0的vector

? ? std::vector<int> obj(5,12138); 创建一个容量为5且默认值为12138的vector

??? std::cout << obj.capacity() << std::endl; 查看当前vector容量

??? std::cout << obj.size() << std::endl;查看当前vector元素个数

??? for (size_t i = 0; i < obj.size(); i++) 遍历输出vector

??? {

??? ??? std::cout << obj[i] << std::endl;

??? }

??? std::vector<int> obj2(obj); 拷贝obj

??? for (size_t i = 0; i < obj.size(); i++) 遍历输出obj2元素值

??? {

??? ??? std::cout << obj2[i] << std::endl;

??? }

? ? obj[1] = 222; 可以直接对vector元素进行修改

? ? obj.at(2) = 333; 此方法也可进行修改元素

??? for (size_t i = 0; i < obj.size(); i++) 遍历输出vector元素

??? {

??? ??? std::cout << obj[i] << std::endl; 使用其特性操作符[]

??? }

??? std::cout << typeid(std::vector<int>::iterator::iterator_category).name() << std::endl; 输出迭代器类型

??? ++ -- += + - -= * [] 随机访问迭代器的特性操作符

??? ?begin end 执行第一个和最后一个的下一个元素

??? cbegin cend 常量

??? rbegin rend 反向

? ? obj.begin() 获取obj首元素地址

??? std::cout << *(++obj.begin()) << std::endl; 打印begin下一个元素

? ? *obj.begin() = 147; 修改第一个元素为147

? ? *(obj.begin()+2) = 147; 修改第三个元素为147

? ? for(auto i = obj.begin(); i != obj.end(); i++)使用迭代器进行循环遍历

? ? {
??????? std::cout << *i << std::endl;

? ? } 可正常打印

??? ??? for (size_t i = 0; i < obj.size(); i++) 初始化vector

??? {

?????? obj[i] = i;

??? }

? ? for (auto i = obj.rbegin(); i != obj.rend(); i++) 利用反向迭代器进行遍历打印

??? {

??? ??? std::cout << *i << std::endl;

??? }

??? std::cout << obj.front() << std::endl; 访问首元素

??? std::cout << obj.back() << std::endl; 访问尾元素

??? obj.push_back(5); 再尾部插入元素5

??? std::cout << obj.back() << std::endl;再次打印尾部元素,发现是5

??? obj.insert(obj.begin() + 2, 555); 在下标2位置插入元素555

??? obj.pop_back(); 删除尾部元素

??? obj.erase(obj.begin() + 2); 删除下标2位置元素

??? for (auto i = obj.begin(); i != obj.end(); i++)

??? {

?????? std::cout << *i << std::endl;

??? }

???

??? std::cout << obj.capacity() << std::endl;每当多加入一个元素,容量就加一,但此时再删除元素,容量不变,经上述代码执行,容量为7

??? std::cout << obj.size() << std::endl; 元素个数为5

? ? obj.clear();清除所有元素

??? for (auto i = obj.begin(); i != obj.end(); i++)

??? {

?????? std::cout << *i << std::endl;

??? }

此时无法遍历,因为没有元素

return 0;

}

文章来源:https://blog.csdn.net/2301_78838647/article/details/135758749
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。