当前位置:  编程技术>c/c++/嵌入式

关于STL中vector容器的一些总结

    来源: 互联网  发布时间:2014-10-20

    本文导语:  1.vector的简单介绍 vector作为STL提供的标准容器之一,是经常要使用的,有很重要的地位,并且使用起来也是灰常方便。vector又被称为向量,vector可以形象的描述为长度可以动态改变的数组,功能和数组较为相似。实际上更专业...

1.vector的简单介绍

vector作为STL提供的标准容器之一,是经常要使用的,有很重要的地位,并且使用起来也是灰常方便。vector又被称为向量,vector可以形象的描述为长度可以动态改变的数组,功能和数组较为相似。实际上更专业的描述为:vector是一个多功能的,能够操作多种数据结构和算法的模板类和函数库,vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。(注:STL的容器从实现的角度讲可以说是类模板(class teplate)。)

那么vector和数组的主要区别是什么呢??这对于理解vector是很有帮助的~~~~

数组:分配的是静态空间,一般分配了就不可以改变,就像我们熟知的定义了一个数组,那么数组的长度就不可以改变了,我们也不可以进行越界访问,但是编译器不检查越界,这一点在我们编程的时候要尤为注意(很多都可能会烦这样的错误!!)。一般申请的数组长度不能满足我们的要求了,我们要重新申请大一点数组,然后把原数组中数据复制过来。

vector:分配的是动态空间,即:我们发现在声明vector容器的时候也可以不指定容器的大小,vector是随着元素的加入,空间自动扩展的。但是,我们必须要负责任的肯定vector分配的空间是连续的,也就是支持数组中的下标随机访问,实际上vector的实现机制是:预留一部分空间,而且预留空间的大小是按一定比率增长的,如果空间不够用的话,要保证连续,就必须重新new一片空间,然后将原有元素移动到新空间,同时预留新的空间(并且新分配的空间比原来分配的空间),最后将原来的那部分空间释放掉。这样预留空间的好处就是不用每次向vector中加元素都重新分配空间。

2.vecotr容器中常用的函数

2.1.vector容器的构造函数

vector容器的声明方式主要包括一下几种:

--------------------------------------------------------------------------------

vector v   ,创建一个空的vector。

vector v1(v)   ,复制一个vector。

vector v(n)  ,创建一个vector,含有n个数据,数据均已缺省构造产生。

vector v(n, elem)   ,创建一个含有n个elem拷贝的vector。

vector v(beg,end)   ,创建一个以[beg;end)区间的vector。

v.~ vector ()  ,销毁所有数据,释放内存。

--------------------------------------------------------------------------------

下面用一段代码来演示几种常用的声明vector的的方式:

代码如下:

#include
#include

using namespace std;

int main()
{
    vector::iterator iter;
    //第一种方式
    vector v1;
    v1.push_back(1);
    v1.push_back(2);
    v1.push_back(3);
    cout


    
 
 

您可能感兴趣的文章:

  • c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例
  • 请问STL中的所有容器(map,multimap,list,queue,vector,set,multiset.......)在BOOST中都可以找到么
  • c++ stl容器vector删除(erase),遍历等基本用法介绍及头文件
  • STL各个容器性能详细比较
  • c++ stl栈容器stack的pop(),push()等用法介绍及头文件
  • 过河小兵,求救各位大哥,我想把stl中的map,vector等容器,做成内存共享方式,希望大哥大姐们指点一下
  • c++ STL关联式容器Map成员函数介绍及查找(find()),插入(insert()),删除(erase())等操作代码举例
  • 浅析stl序列容器(map和set)的仿函数排序
  • 双向队列Deque 类成员函数列表参考(c++ STL 容器)
  • stl容器set,map,vector之erase用法与返回值详细解析
  • STL常用容器详细解析
  • 深入解析C++ STL中的常用容器
  • 关于STL中list容器的一些总结
  • c++ STL容器总结之:vertor与list的应用
  • 关于STL中的map容器的一些总结
  • 关于STL中set容器的一些总结
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • STL vector+sort排序和multiset/multimap排序比较
  • stl SORT vector 内存翻倍
  • 我想把STL中的vector,map,set,multimap,multiset的所有操作修改成线程安全的,可以么
  • linux下的gcc为何不能编译stl的vector<>.at()
  • C++ STL Bitsets构造函数及成员函数解释及代码示例
  • SGI的STL库 SGI STL
  • C++ STL标准模板库类String成员详细列表参考及示例代码
  • 在UNIX中可以包含STL算法吗?
  • C++ stl队列Queue用法介绍:删除,插入等操作代码举例
  • linux完全支持C++STL嗎?
  • C++ STL库中priority_queue介绍,成员函数说明及priority_queue具体用法举例
  • 是不是只有C++才可以使用STL?
  • c++ stl multimap基本操作使用技巧详细介绍
  • STL 在 UNIX 多线程 中不能用?
  • c++ STL List查找遍历及各成员函数用法详细介绍
  • Linux系统下如何获取STL帮助
  • C++ STL MultiSet类成员函数介绍及具体用法示例
  • STL实现 EASTL
  • 在COMPAQ TRUE64 UNIX用C++编程,使用Gcc,支不支持stl?
  • 哪儿能下载aix4.3的c++ stl库
  • 请问在linux下面编程怎样查询stl类的成员函数
  • 关于stl源代码
  • 请问如果要同时使用STL和多线程,会很麻烦么
  • linux下用c语言写的程序,其中可以使用STL模板吗?先谢谢各位
  • 如果是系统里同时存在两个不同的STL库的话会怎样?




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3