vector容器
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容器的更多相关文章
- 把《c++ primer》读薄(3-2 标准库vector容器+迭代器初探)
督促读书,总结精华,提炼笔记,抛砖引玉,有不合适的地方,欢迎留言指正. 标准库vector类型初探,同一种类型的对象的集合(类似数组),是一个类模版而不是数据类型,学名容器,负责管理 和 存储的元素 ...
- C++ STL vector容器学习
STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...
- vector容器使用和assert断言关键字
C++里面的容器是个比较复杂的东西,我这篇只说vector容器怎么使用,详细的网搜. vector模板类其实是一个动态数组,跟自己用new关键字创建数组一样,只不过vector会自动帮我们用new和d ...
- C++杂谈(二)初识vector容器与迭代器
教科书中失踪的vector 很奇怪的一件事情,在当时学习C++的时候,老师并没有讲授容器的内容,当时参考的谭浩强老师的红皮C++也没有这个内容,不知为何.后来再学C++,发现容器是一个很重要的概念,在 ...
- vector容器的用法
转自一篇博客^-^: 1 基本操作 (1)头文件#include<vector>. (2)创建vector对象,vector<int> vec; (3)尾部插入数字:vec.p ...
- C++ Daily《2》----vector容器的resize 与 reserve的区别
C++ STL 库中 vector 容器的 resize 和 reserve 区别是什么? 1. resize 改变 size 大小,而 reserve 改变 capacity, 不改变size. 2 ...
- 跟我一起学STL(2)——vector容器详解
一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...
- vector容器+iterator迭代器
关于vector容器的详细描述,可参考:http://www.jb51.net/article/41648.htm 关于iterator迭代器的描述,可参考http://www.cppblog.c ...
- 提高Vector容器的删除效率
vector容器是类似与一个线性数组,索引效率高,插入,删除的效率很低,需要遍历数据列表,一般情况下vector的删除操作由一下函数完成: iterator erase(iterator positi ...
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
随机推荐
- python的工作记录A
马上进入工作自动化: [root@localhost ~]# cat svn_bbs.py import os,sys,commands,subprocess import re,time svnUr ...
- C++11之后,对源代码增加了UTF8和UCS4的支持(Windows内部使用Unicode,因为nt内核用的是ucs2,那是89年,utf8到了92年才发明出来)
在C++编程中, 我们常打交道的无非是编辑器和编译器, 对编辑器起来说,我们常遇到就是乱码问题, 比如中文注释显示或是保存不了等, 解决办法就是把你的文件保存成Unicode(UTF8). 对于编译器 ...
- HDU-1241Oil Deposits
Description GeoSurvComp地质调查公司负责探测地下石油储藏. GeoSurvComp现在在一块矩形区域探测石油,并把这个大区域分成了很多小块.他们通过专业设备,来分析每个小块中是否 ...
- 远程连接mysql
win系统下,连接别人的mysql或者让别人链接自己的mysql: 打开命令行cmd 进入mysql: mysql -u root -p mysql>use mysql; mysql>s ...
- C#_Test
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Plus ...
- oracle 性能优化--索引总结
索引是建立在表的一列或多个列上的辅助对象,目的是加快訪问表中的数据: Oracle存储索引的数据结构是B*树.位图索引也是如此,仅仅只是是叶子节点不同B*数索引: 索引由根节点.分支节点和叶子节点组成 ...
- Windows下Hadoop的环境安装[转]
1.下载并安装Cygwin,记得cygwin安装中要把SSH选择上,因为后面Hadoop会用到,不详述cygwin的安装过程.我是安装在D:\cygwin下 2.配置系统环境变量 在windows命令 ...
- android requestDisallowInterceptTouchEvent用途
ViewPager来实现左右滑动切换tab.假设tab的某一项中嵌入了水平可滑动的View就会让你有些不爽,比方想滑动tab项中的可水平滑动的控件,却导致tab切换. 由于Android事件机制是从父 ...
- android ViewFlipper的使用
有个android.widget.ViewAnimator类继承至FrameLayout,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.该类有如下几个和动画 ...
- js验证表单并提交
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...