vector<int> ivec;
vector<Sales_item> Sales_vec;
和其他变量定义一样,定义 vector 对象要指定类型和一个变量的列表。上
面的第一个定义,类型是 vector<int>,该类型即是含有若干 int 类型对象的
vector,变量名为 ivec。第二个定义的变量名是 Sales_vec,它所保存的元素
是 Sales_item 类型的对象。

vector<T> v1; vector 保存类型为 T 对象。默认构造函数 v1 为空。
vector<T> v2(v1); v2 是 v1 的一个副本。
vector<T> v3(n, i); v3 包含 n 个值为 i 的元素。
vector<T> v4(n); v4 含有值初始化的元素的 n 个副本。

v.empty() 如果 v 为空,则返回 true,否则返回 false。

v.size() 返回 v 中元素的个数

v.empty() 如果 v 为空,则返回 true,否则返回 false。

v.push_back(t) 在 v 的末尾增加一个值为 t 的元素。

v[n] 返回 v 中位置为 n 的元素。

v1 = v2 把 v1 的元素替换为 v2 中元素的副本
。
v1 == v2 如果 v1 与 v2 相等,则返回 true。

!=, <, <=,>, and >=保持这些操作符

ector函数表
 vector<T>是可边长的向量,比较灵活
☆ value_type;//对象类型T,存储在vector中 [定义地方:容器]
☆ pointer;//指向T的指针 [容器]
☆ reference;//T的引用 [容器]
☆ const_reference;//T的常量引用 [容器]
☆ size_type;//正整数类型 [容器]
☆ difference_type;//整数类型 [容器]
☆ iterator ;//访问vector的迭代器 [容器]
☆ const_iterator;//访问vector的常量迭代器 [容器]
☆ reverse_iterator;//访问vector的反向迭代器 [Reversible容器]
☆ const_reverse_iterator;//访问vector的反向迭代器 [Reversible容器]
☆ iterator begin();//返回vector的头指针 [容器]
☆ iterator end();//返回vector的尾指针 [容器]
☆ const_iterator begin() const;//返回vector的常量头指针 [容器]
 ☆ const_iterator end() const;//返回vector的常量尾指针 [容器]
☆ reverse_iterator rbegin();//返回反向vector的反向头指针 [Reversible容器]
☆ reverse_iterator rend();//返回反向vector的反向尾指针 [Reversible容器]
☆ const reverse_iterator rbegin() const;//返回反向vector的反向常量头指针 [Reversible容器]
☆ const_reverse_iterator rend() const();//返回反向vector的反向常量尾指针 [Reversible容器]
☆ size_type size() const;//返回vector的元素数量 [容器]
☆ size_type max_size() const;// 返回最大可允许的vector元素数量值 [容器]
☆size_type capacity() const;//返回当前所能容纳的最多元素个数 [vector]
☆bool empty() const;//判断vector是否为空 [容器]
☆reference operator[](size_type n); //返回第n个元素 [Random Access容器]
☆const_reerence operator[](size_type n)const; //返回第n个元素 [Random Access容器]
☆vector();//创建一个空vector [容器]
☆vector(size_type n);//创建一个vector,元素数量为n [Sequence]
☆vector(size_type n, const T& t);//创建一个vector,元素数量为n,大小都为t[Sequence]
☆vector(const vector &);//拷贝构造函数 [容器]
☆template<class InputIterator>vector(InputIterator, InputIterator); [Sequence] //采用拷贝的方法创建一个vector,指定了范围 ☆~vector();// vector的析构函数 [容器]
☆vector& operator=(const vector&);//=运算符重载 [容器]
☆void reserve(size_t n);//为vector预先分配n个元素 [vector]
☆reference front();// 返回第一个元素 [Sequence] ☆const_reference front() const;//返回第一个元素 [Sequence] ☆reference back();//返回最后一个元素 [Back Insertion Sequence]
☆const_reference back() const;//返回最后一个元素 [Back Insertion Sequence]
☆void push_back(const T&);//在vector尾部插入一个元素 [Back Insertion Sequence]
☆void pop_back();//删除最后一个元素 [Back Insertion Sequence]
☆void swap(vector&);//交换两个vector的内容 [容器]
☆iterator insert(iterator pos, const T& x);//在pos前出入x [Sequence]
☆template<class InputIterator>void insert(iterator pos, InputIteratorf, InputIterator I); //在位置pos位置前插入范围为[fisrt, last]的元素 [Sequence]
 ☆void insert(iterator pos, size_type n, const T& x);//在位置pos前出入n个x [Sequence]
☆iterator erase(iterator pos);//删除在位置pos的元素 [Sequence]
 ☆iterator erase(iterator first, iterator last);//删除在[first, last]之间的元素 [Sequence]
☆void clear();//删除所有的元素 [Sequence]
☆void resize(size_type n, t = T());//插入或删除使元素个数为n插入的值为t[Sequence]
☆bool operator==(const vector&, const vector&);//重载==运算符 [Forward容器]
☆bool operator<(const vector&, const vector&);//小于逻辑运算符 [Forward容器]
vector类的私有成员:
☆size_type capacity() const;//返回当前所能容纳的最多元素个数,其值不小于size()
 ☆void reserve(size_type n);//如果n小于或等于capacity(),本函数没有作用。否则,它申请分配内存如果申请成功,capacity()值应>=n:如果申请失败,capacity()不变  

vector容器的更多相关文章

  1. 把《c++ primer》读薄(3-2 标准库vector容器+迭代器初探)

    督促读书,总结精华,提炼笔记,抛砖引玉,有不合适的地方,欢迎留言指正. 标准库vector类型初探,同一种类型的对象的集合(类似数组),是一个类模版而不是数据类型,学名容器,负责管理 和 存储的元素 ...

  2. C++ STL vector容器学习

    STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...

  3. vector容器使用和assert断言关键字

    C++里面的容器是个比较复杂的东西,我这篇只说vector容器怎么使用,详细的网搜. vector模板类其实是一个动态数组,跟自己用new关键字创建数组一样,只不过vector会自动帮我们用new和d ...

  4. C++杂谈(二)初识vector容器与迭代器

    教科书中失踪的vector 很奇怪的一件事情,在当时学习C++的时候,老师并没有讲授容器的内容,当时参考的谭浩强老师的红皮C++也没有这个内容,不知为何.后来再学C++,发现容器是一个很重要的概念,在 ...

  5. vector容器的用法

    转自一篇博客^-^: 1 基本操作 (1)头文件#include<vector>. (2)创建vector对象,vector<int> vec; (3)尾部插入数字:vec.p ...

  6. C++ Daily《2》----vector容器的resize 与 reserve的区别

    C++ STL 库中 vector 容器的 resize 和 reserve 区别是什么? 1. resize 改变 size 大小,而 reserve 改变 capacity, 不改变size. 2 ...

  7. 跟我一起学STL(2)——vector容器详解

    一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...

  8. vector容器+iterator迭代器

    关于vector容器的详细描述,可参考:http://www.jb51.net/article/41648.htm   关于iterator迭代器的描述,可参考http://www.cppblog.c ...

  9. 提高Vector容器的删除效率

    vector容器是类似与一个线性数组,索引效率高,插入,删除的效率很低,需要遍历数据列表,一般情况下vector的删除操作由一下函数完成: iterator erase(iterator positi ...

  10. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

随机推荐

  1. CSS5.4 安装问题集

    由于手痒,将5.2 卸载了,装了5.4 出现如下错误:install failed to install com.ti.ccstudio.debugserver.win32 corrctly. ... ...

  2. BZOJ 2300 防线修建

    http://www.lydsy.com/JudgeOnline/problem.php?id=2300 题意:给点,有以下操作:删去一个点,询问这些点构成凸包的周长. 思路:用splay维护上凸壳, ...

  3. android 通过post方式提交数据的最简便有效的方法

    public boolean post(String username, String password) throws Exception { username = URLEncoder.encod ...

  4. Android attrs.xml文件中属性类型format值的格式

    "reference" //引用 "color" //颜色 "boolean" //布尔值 "dimension" // ...

  5. 【C++基础之十一】虚函数的用法

    虚函数的作用和意义,就不进行说明了,这里主要讨论下虚函数的用法. 1.典型的虚函数用法 可以看到,只有标识为virtual的函数才会产生多态的效果,而且是编译多态.它只能借助指针或者引用来达到多态的效 ...

  6. 【8】JAVA---地址App小软件(AddrDaoFile .class)(数据层)

    实现数据进行文件的存储和读写. 本软件也就到此结束了. 没多少可以讲的. 因为这个小软件也就8个类,主要学习的也就是一个分层思想的简单应用. package cn.hncu.addr.dao; imp ...

  7. SRM 585 DIV1

    A 树形dp是看起来比较靠谱的做法 , 但是转移的时候不全面就会出错 , 从贪心的角度出发 , 首先让第一量车走最长路, 然后就会发现递归结构 , 得到递归式 f[i] = ( f[i-2] + f[ ...

  8. tungsten开机启动及进程开启停止

  9. React问答小demo

    在学习react初期,看了一些视频和资料,react基础知识差不多学完,跟着网上的一个教程,做了一个小型的问答demo. 需求看图说: 1.点击"添加"按钮,显示问题输入表单,再次 ...

  10. 对Ul下的li标签执行点击事件——如何获取你所点击的标签

    问题所来:做项目时,一般的数据都是用循环动态加载出来的,结构都是一样的,只是绑定的值不同,如何对相同的标签做处理的问题就来了. 例如:点谁就显示谁的数值 <ul > <li id=& ...