vector笔记
来源:互联网 发布:有什么人工智能机器人 编辑:程序博客网 时间:2024/06/05 02:43
1.capacity()和size()的区别
capacity()返回值指的是在不调用分配器重新分配vector大小的情况下,当前vector所能保存最大的容量值。
size()返回值指的是当前vector内有多少个元素。
我们通过代码来详细看看它们的区别:
//代码1 //构造vector,容量大小为10,10个元素初值为0 vector<int> a(10); int i = 0; cout<<"capacity() = "<<a.capacity()<<endl; cout<<"size() = "<<a.size()<<endl; for (i=0;i<a.size();i++) { cout<<a[i]<<" "; } cout<<"\n\n";
//代码2 //构造vector,容量大小为10,10个元素初值为0 vector<int> a(10); int i = 0; //删除vector中所有元素 a.clear(); cout<<"capacity() = "<<a.capacity()<<endl; cout<<"size() = "<<a.size()<<endl; for (i=0;i<a.size();i++) { cout<<a[i]<<" "; } cout<<"\n\n";
代码1和代码2的唯一区别是代码2多了一句a.clear();通过看代码1和代码2的运行结果,我们就很容易理解这两者的区别了。
代码1:
代码2:
2.reverse()和resize()区别
这两个函数都可以用于改变vector容量。
分两种情况来讨论:
a)扩大vector容量
reverse():只扩容vector容量,即改变capacity()大小,不改变size()大小
resize():既改变capacity()大小也改变size大小
//resize vector<int> v(5); int i = 0; cout<<"Original contents of v : \n"; for (i=0;i<v.size();i++) { cout <<v[i]<<" "; } cout<<"\n\n"; v.resize(10); cout<<"after resize(10), contents of v : \n"; for (i=0;i<v.size();i++) { cout <<v[i]<<" "; } cout<<"\n\n"; cout<<"capacity() = "<<v.capacity();
结果:
//reverse vector<int> v(5); int i = 0; cout<<"Original contents of v : \n"; for (i=0;i<v.size();i++) { cout <<v[i]<<" "; } cout<<"\n\n"; v.reserve(10); cout<<"after reverse(10), contents of v : \n"; for (i=0;i<v.size();i++) { cout <<v[i]<<" "; } cout<<"\n\n"; cout<<"capacity() = "<<v.capacity();
结果:
从这两个运行结果来看,当vector由resize(10)执行后capacity()大小由5变为10,其的size()也由5变为10,resize()会对用元素将新增的容量填满;而vector由reverse(10)执行后,只是把vector的capacity()容量大小变为10,不会填充新元素。
b)“缩小”vector
原vector的capacity()为5,size()也为5.
执行resize(3)后,vector的capacity()还是为5,size()为3;
执行reverse(3)后,vector的capacity()还是为5,size()还是为5;
也就是说如果resize(num)和reverse(num)中的num小于原来的vector的capacity()值,那么不会改变vector容量大小,原因是不会vector不会重新分配内存。
具体可以参看vector中关于这两个函数的实现:
void resize(size_type _Newsize) { // determine new length, padding with _Ty() elements as needed if (_Newsize < size()) erase(begin() + _Newsize, end()); else if (size() < _Newsize) { // pad as needed ...... } }
void reserve(size_type _Count) { // determine new minimum length of allocated storage if (max_size() < _Count) _Xlen(); // result too long else if (capacity() < _Count) { // not enough room, reallocate ...... } }
3.下标和at()区别
vector提供两种索引访问元素的方法,一个是类似与数组的下标[],另一个是at()函数,它们的返回值都是索引i位置的元素。
它们两者的主要区别是:当访问越界元素时,at()函数会抛出out_of_range异常,而下标访问越界元素时,行为则是未知的。
- vector笔记
- vector 笔记
- vector笔记
- vector笔记
- Vector学习笔记
- vector 学习笔记
- STD::vector 用法笔记
- STL学习笔记【vector】
- Vector学习笔记
- stl vector 笔记
- vector学习笔记
- 【STL】vector学习笔记
- vector的学习笔记
- vector 学习笔记
- c++ vector使用笔记
- Fisher vector学习笔记
- Vector学习笔记
- C++vector学习笔记
- C#接口的作用
- Linux ps命令详解与示例说明
- Eclipse部署Maven web项目到tomcat服务器时,没有将lib下的jar复制过去的解决办法
- a标签使用href=”javascript:void(0); 在火狐浏览器跟chrome 不兼容
- Android 中文 API(123) —— AbsListView
- vector笔记
- Log4j2 SMTPAppender 配置与使用
- iOS静态库中打包图片资源
- 【数据结构】单链表的基本操作
- Android Studio TraceView性能优化分析
- mysql索引结构原理、性能分析与优化
- Jenkins构建maven项目时日志报代码缺少jar包错误的解决办法
- MRC到ARC的自动转换
- ios -- NSNotification(通知)