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之所以被 ...
随机推荐
- 高性能web
http://developer.51cto.com/art/201104/255619.htm http://developer.51cto.com/art/201104/254031.htm ht ...
- WebBrowser执行脚本
ExecuteJavaScript(WebBrowser:TWebBrowser; Code: string):Variant;var //发送脚本Document:IHTMLDocument2;Wi ...
- bzoj3767 A+B Problem加强版
Description Input 输入A,B Output 输出A+B. Sample Input 1 1 Sample Output 2 HINT 对于100%的数据,保证 |A| , | ...
- 命名实参和可选实参(C# 编程指南)
https://msdn.microsoft.com/zh-cn/library/dd264739.aspx CalculateBMI(weight: 123, height: 64); Calcul ...
- Bozo排序
Bogo的变种,继续卖萌... Bogo每次都随机打乱数组,而Bozo每次随机选择两个位置,然后交换这两个位置的值.相同的是不断靠概率不断查看有序了没... public static void bo ...
- HBase 事务和并发控制机制原理
作为一款优秀的非内存数据库,HBase和传统数据库一样提供了事务的概念,只是HBase的事务是行级事务,可以保证行级数据的原子性.一致性.隔离性以及持久性,即通常所说的ACID特性.为了实现事务特性, ...
- UVa 1366 - Martian Mining (dp)
本文出自 http://blog.csdn.net/shuangde800 题目链接: 点击打开链接 题目大意 给出n*m网格中每个格子的A矿和B矿数量,A矿必须由右向左运输,B矿必须由下向上运输 ...
- ORACLE STUDY NOTES 01
[JSU]LJDragon's Oracle course notes In the first semester, junior year DML数据操纵语言 DML指:update,delete, ...
- [原创作品]一个实用的js倒计时器 postby:zhutty.cnblogs.com
今天做了一个手机短信发送倒计时,额,就是每隔多长时间可以重新发送的功能.贡献出来给园有吐槽点评. //倒计时,time:时长(秒),scb:每秒回调,cb:计时完成回调 var timing = fu ...
- Redis起步
Rdis和JQuery一样是纯粹为应用而产生的,这里记录的是在CentOS 5.7上学习入门文章: 1.Redis简介 Redis是一个key-value存储系统.和Memcached类似,但是解决 ...