代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v1;for (int i = 0; i < 10; i++){v1.push_back(i);}printVector(v1);vector<int>v2(v1.begin(), v1.end());printVector(v2);vector<int>v3(10, 100);printVector(v3);vector<int>v4(v3);printVector(v4);
}int main()
{test01();return 0;
}

测试结果:

总结:
vector的多种构造方式没有可比性,灵活使用即可。

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v1;for (int i = 0; i < 10; i++){v1.push_back(i);}printVector(v1);vector<int>v2;v2 = v1;printVector(v2);vector<int>v3;v3.assign(v1.begin(), v1.end());printVector(v3);vector<int>v4;v4.assign(10, 100);printVector(v4);
}int main()
{test01();return 0;
}

测试结果:

总结:
vector赋值方式比较简单,使用operator=,或者assign都可以。

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int> v1;for (int i = 0; i < 10; i++){v1.push_back(i);}printVector(v1);if (v1.empty()){cout << "v1为空" << endl;}else{cout << "v1不为空" << endl;cout << "v1 capacity = " << v1.capacity() << endl;cout << "v1 size = " << v1.size() << endl;}v1.resize(15, 10);printVector(v1);v1.resize(5);printVector(v1);
}int main()
{test01();return 0;
}

测试结果:

总结:

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v1;v1.push_back(10);v1.push_back(20);v1.push_back(30);v1.push_back(40);v1.push_back(50);printVector(v1);v1.pop_back();printVector(v1);v1.insert(v1.begin(), 100);printVector(v1);v1.insert(v1.begin(), 2, 1000);printVector(v1);v1.erase(v1.begin());printVector(v1);//清空v1.erase(v1.begin(), v1.end());v1.clear();printVector(v1);}int main()
{test01();return 0;
}

测试结果:

总结:


代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v1;for (int i = 0; i < 10; i++){v1.push_back(i);}for (int i = 0; i < v1.size(); i++){cout << v1[i] << " ";}cout << endl;for (int i = 0; i < v1.size(); i++){cout << v1.at(i) << " ";}cout << endl;cout << "v1 front elem = " << v1.front() << endl;cout << "v1 final elem = " << v1.back() << endl;}int main()
{test01();return 0;
}

测试结果:

总结:

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v1;for (int i = 0; i < 10; i++){v1.push_back(i);}printVector(v1);vector<int>v2;for (int i = 10; i > 0; i--){v2.push_back(i);}printVector(v2);//互换容器cout << "互换后" << endl;v1.swap(v2);printVector(v1);printVector(v2);}void test02()
{vector<int>v;for (int i = 0; i < 100000; i++){v.push_back(i);}cout << "v capacity = " << v.capacity() << endl;cout << "v size = " << v.size() << endl;v.resize(3);cout << "v capacity = " << v.capacity() << endl;cout << "v size = " << v.size() << endl;//收缩内存vector<int>(v).swap(v);cout << "v capacity = " << v.capacity() << endl;cout << "v size = " << v.size() << endl;}int main()
{test01();test02();return 0;
}

测试结果:

总结:

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v;/*v.reserve(100000);*/int num = 0;int *p = nullptr;for (int i = 0; i < 100000; i++){v.push_back(i);if (p != &v[0]){p = &v[0];num++;}}cout << "num = " << num << endl;}int main()
{test01();return 0;
}

测试结果:

代码如下:

#include <iostream>
#include <string>
#include <vector>
using namespace std;void printVector(vector<int >&v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << " ";}cout << endl;
}void test01()
{vector<int>v;v.reserve(100000);int num = 0;int *p = nullptr;for (int i = 0; i < 100000; i++){v.push_back(i);if (p != &v[0]){p = &v[0];num++;}}cout << "num = " << num << endl;}int main()
{test01();return 0;
}

测试结果:

总结:

[C++STL]vector容器用法介绍相关推荐

  1. [C++STL]deque容器用法介绍

    代码如下: #include <iostream> #include <string> #include <deque> using namespace std;v ...

  2. [C++STL]set容器用法介绍

    代码如下: #include <iostream> #include <set> using namespace std;void printSet(set<int> ...

  3. [C++STL]list容器用法介绍

    代码如下: #include <iostream> #include <string> #include <list> using namespace std;vo ...

  4. [C++STL]map容器用法介绍

    代码如下: #include <iostream> #include <string> #include <map> using namespace std;voi ...

  5. [C++STL]queue容器用法介绍

  6. [C++STL]stack容器用法介绍

  7. [C++STL]string容器用法介绍

    string构造函数 代码如下: #include <iostream> #include <string> using namespace std;void test01() ...

  8. STL vector 容器介绍

    介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...

  9. STL vector 容器介绍 (转载)

    STL vector 容器介绍<?xml:namespace prefix = o /> A Presentation of the STL Vector Container (By Ni ...

最新文章

  1. 用MATLAB也能做AI系统,而且简单易上手?
  2. St_geometry 初始用
  3. 实时计算Flink 快速入门 —— 步骤二:注册上下游存储
  4. 【C++】accumulate函数的用法(STL)
  5. 数据库设计中char与varchar类型的区别
  6. python 学习笔记 常用模块(五)
  7. hive replace_Hive新增字段(column)后,旧分区无法更新数据问题
  8. 纽微特纪事:吾是如何被架空的(各位引以为戒)
  9. java对象调用方法,java 对象调用
  10. Vue前端开发环境搭建
  11. java static 详解
  12. html js 鼠标变图片大小,js之图片变大变小效果
  13. 【进阶】QQ聊天机器人--群聊机器人篇
  14. 团购幸存者:团购是个苦生意
  15. sketch插件开发
  16. HDWiki软件包结构
  17. 简单使用一下IDEA 的HTTP Client
  18. Win10系统重装过程(一键装机)
  19. 前端页面中根据链接随机生成二维码
  20. 计算机秋招必备!杭州互联网大厂企业整理清单!

热门文章

  1. 【ArcGIS遇上Python】Python实现点转栅格(PointToRaster)
  2. C和指针之字符串简单实现 strcpy、strcat、strstr函数
  3. Android之通过ActivityLifecycleCallbacks判断程序是否运行在后台
  4. Android插件化开发基础之App如何动态加载类
  5. 判断一棵树是否为平衡二叉树
  6. 微信改成右滑删除_手机文件数据恢复,怎样恢复已过期的微信附件呢?
  7. 几何学中关于相交圆的这个定理,你还记得吗?
  8. 从时速100公里行驶的车上向后发射时速100公里的棒球,会发生什么?
  9. 一个娃娃竟然拍出50万......
  10. 钢厂冒的白烟到底有没有污染?东北大学教授的试验结果让你大吃一惊