STL-vector

STL学习之二 序列容器(vector)
一、C++标准模板库提供了三种序列容器:vector、list、deque。类模板vector和deque都以数组为基础,类模板list实现了链表的数据结构。
STL中最流行的是类模板vector,它是一种更健壮的数据类型,相当于动态数组,能动态得改变数组的大小。
Vector和C和C++的原始数组不同。为什么不同呢?因为vector能够彼此赋值,基于指针的C风格的数组不支持这种用法,为什么呢?因为这些数组的名称是常量指针,不能作为赋值的目标。就像C数组一样,vector的下标并不执行自动范围检查,但模板vector通过at成员函数可以对数组下标范围进行检查,待会在例子中将会看到。呵呵
vector、list、deque各有各的高效使用范围:
vector用于在容器的后端高效的的插入,在中间插入和删除元素的效率很低;
list用于经常在容器的中间位置和两个端点进行插入和删除;
deque经常用于对容器的两端进行高效的插入和删除;
1、 vector序列容器
类模板vector提供的数据结构,具有连续的内存位置,这样,就能够通过下标运算符[]高效而直接的访问vector中的任何一个元素,就像C和C++的原始数组一样。
当vector的内存耗尽的时候,它会分配一块更大的连续内存区域,将原来的元素复制到心得内存中并销毁旧的内存。
下面将介绍使用vector和迭代器,直接上demo
#include <iostream>  
using namespace std;  
#include <vector>  
template <typename T> void printVector(const vector<T> &integers2);  
  
int _tmain(int argc, _TCHAR* argv[])  
{  
 const int SIZE=6;  
 int array[SIZE]={1,2,3,4,5,6};   //初始化数组  
 vector<int> integers;  
 //下面两行演示了size和capacity函数的用法  
 cout<<"n初始化数组大小是:"<<integers.size();  
 cout<<"\n初始化数组容量是:"<<integers.capacity();  
  
 //push_back将一个元素添加到vector末尾,这个函数可用于所有的序列容器  
 integers.push_back(2);  
 integers.push_back(3);  
 integers.push_back(4);  
    //此处结果按照道理应该是4,因为添加第一个元素时分配1个元素空间,添加第二个元素的时候,大小为2,  
 //添加第三个元素的时候大小为4,它是以1、2、4、8......这样分配的,但是这里运行结果却是3,求解  
 cout<<"\n数组大小是:"<<integers.size();  
 cout<<"\n数组容量是:"<<integers.capacity();  
  
 //演示用指针和指针运算符输出数组的内容  
 cout<<"\n用指针输出数组";  
 for (int *ptr=array;ptr!=array+SIZE;ptr++)  
 {  
  cout<<*ptr<<' ';  
 }  
 cout<<"\n用迭代去输出vector:";  
 //调用printVector函数,通过迭代器输出vector对象的内容  
 printVector(integers);  
 cout<<"\n翻转vector的元素:";  
   
 //const_reverse_iteratory用于逆向迭代vector  
 vector<int>::const_reverse_iterator reverseIterator;  
 vector<int>::const_reverse_iterator tempIterator=integers.rend();  
  
 for (reverseIterator=integers.rbegin();reverseIterator!=tempIterator;++reverseIterator)  
 {  
  cout<<*reverseIterator<<' ';  
 }  
 cout<<endl;  
 system("pause");  
 return 0;  
}  
  
template<typename T> void printVector(const vector<T> &integers2)  
{  
 typename vector<T>::const_iterator constIterator;  
 for (constIterator=integers2.begin();constIterator!=integers2.end();++constIterator)  
 {  
  cout<<*constIterator<<' ';  
 }  

}  


输出结果为:
初始化数组大小是:0
初始化数组容量是:0
数组大小是:3
数组容量是:3
用指针输出数组:1 2 3 4 5 6
用迭代器输出vector:2 3 4
翻转vector中的元素:4 3 2
注:迭代器的行为就像指向元素的指针一样,它重载了运算符*,返回指向这个元素的引用。
操作vector元素的函数
直接上demo
#include <iostream>  
using namespace std;  
#include <vector>  
#include <algorithm>  
#include <iterator>  
#include <stdexcept>  
  
int _tmain(int argc, _TCHAR* argv[])  
{  
 const int SIZE=6;  
 int array[SIZE]={1,2,3,4,5,6};    
 vector<int>integers(array,array+SIZE);  
 ostream_iterator<int> output(cout," ");  
 cout<<"vector元素包括:";  
 //来自标准库的copy算法,将vector对象integers的全部内容输出到标准输出  
 copy(integers.begin(),integers.end(),output);  
  
 cout<<"\n第一个元素是:"<<integers.front()<<"\n最后一个元素是:"<<integers.back();  
  
 integers[0]=7;  //设置第一个元素为7  
 integers.at(2)=10;//设置第二个位置的元素为10  
 //插入22作为第二个元素  
 integers.insert(integers.begin()+1,22);  
  
 cout<<"\n改变后vector元素的内容为:";  
 std::copy(integers.begin(),integers.end(),output);  
  
 //访问越界的元素  
 try  
 {  
  integers.at(100)=777;  
 }  
 catch(out_of_range &outOfRange)  
 {  
  cout<<"\n\nException: "<<outOfRange.what();  
  
 }  
  
 //清除第一个元素  
 integers.erase(integers.begin());  
 cout<<"\n清除第一个元素后为:";  
 copy(integers.begin(),integers.end(),output);  
  
 //清除保留的元素  
 integers.erase(integers.begin(),integers.end());  
 cout<<"\n清除所有的元素后,vector的元素 "<<(integers.empty()?"is":"is not")<<"empty";  
  
 //从数组中插入元素  
 integers.insert(integers.begin(),array,array+SIZE);  
 cout<<"\n\n清除前的内容:";  
 copy(integers.begin(),integers.end(),output);  
  
 integers.clear();  
 cout<<"\n清楚后,vector "<<(integers.empty()?"is":"is not")<<"empty"<<endl;  
 system("pause");  
 return 0;  
}  


 
输出结果为:
Vector元素包括:1 2 3 4 5 6
第一个元素是:1
最后一个元素是:6
改变后vector元素的内容为:7 22 2 10 4 5 6
 
Exception:invalid vector<T> subscript
清除第一个元素后为:22 2 10 4 5 6
清除所有的元素后,vector的元素isempty
 
清除前的内容:1 2 3 4 5 6
清楚后,vector isempty
注:front函数和begin函数的区别:front函数返回vector中第一个元素的引用,而begin函数返回一个随机访问迭代器,指向vector中的第一个元素;
   back函数和end函数的区别:back函数返回vector中最后一个元素的引用,而end函数返回一个随机访问迭代器,指向vector的末尾;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383249.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

套接字编程--1(UDP协议编程,端口号,传输层协议,网络字节序)

传输层的协议&#xff1a; ip地址&#xff1a; 在网络中唯一标识一台主机 IPV4&#xff1a;uint32_t DHCP NATIPV6 : uint8_t addr[16] —向前并不兼容IPV4 每一条数据都必须包含源地址和目的地址&#xff1a;因为每条网络中的数据都必须确定是从那个主机来到那个主机去 端…

ARP简单介绍

ARP简介 ARP&#xff08;Address Resolution Protocol&#xff09;用于将IP地址解析为MAC地址 1. ARP地址解析的必要性 IP地址不能直接用来进行通信&#xff0c;因为网络设备只能识别MAC地址。IP地址只是主机在网络层中的地址&#xff0c;如果要将网络层中传送的数据报交给…

Linux系统编程--3(exec 函数族,僵尸进程和孤儿进程,wait和wait_pid回收子进程)

exec 函数族 fork 创建子进程后执行的是和父进程相同的程序&#xff08;但有可能执行不同的代码分支&#xff09; &#xff0c;子进程往往要调用一种 exec 函数以执行另一个程序。当进程调用一种 exec 函数时&#xff0c;该进程的用户空间代码和数据完全被新程序替换&#xff…

交换机MAC地址学习和转发数据帧的原理

1 &#xff1a;交换机 MAC 地址学习在交换机初始化的&#xff0c;也就是刚启动的时候&#xff0c;交换机的MAC地址表是没有任何MAC地址和端口的映射条目的 当PCA要想和PCC&#xff0c;PCB,PCD进行通信时&#xff0c;当该二层数据帧通过端口E1/0/1发送到交换机上时&#xff0c…

Linux系统编程---4(进程间通信IPC,管道)

进程间通信目的 数据传输&#xff1a;一个进程需要将它的数据发送给另一个进程资源共享&#xff1a;多个进程之间共享同样的资源。通知事件&#xff1a;一个进程需要向另一个或一组进程发送消息&#xff0c;通知它&#xff08;它们&#xff09;发生了某种事件&#xff08;如进…

冲突域 广播域简单解释

网络互连设备可以将网络划分为不同的冲突域、广播域。但是&#xff0c;由于不同的网络互连设备可能工作在OSI模型的不同层次上。因此&#xff0c;它们划分冲突域、广播域的效果也就各不相同。如中继器工作在物理层&#xff0c;网桥和交换机工作在数据链路层&#xff0c;路由器工…

Linux系统编程---5(共享存储映射,存储映射I/O,mmap函数,父子进程间通信,匿名映射)

共享存储映射 文件进程间通信 使用文件也可以完成 IPC&#xff0c;理论依据是&#xff0c;fork 后&#xff0c;父子进程共享文件描述符。也就共享打开的文件。 编程&#xff1a;父子进程共享打开的文件。借助文件进行进程间通信。 测试代码 /*** 父子进程共享打开的文件描述…

变量的存取

一、预备知识―程序的内存分配 一个由c/C编译的程序占用的内存分为以下几个部分 1、栈区&#xff08;stack&#xff09;― 由编译器自动分配释放 &#xff0c;存放函数的参数值&#xff0c;局部变量的值等。其操作方式类似于数据结构中的栈。 2、堆区&#xff08;heap&#xff…

Linux下文件的多进程拷贝

大文件拷贝 假设有一个超大文件&#xff0c;需对其完成拷贝工作。为提高效率&#xff0c;可采用多进程并行拷贝的方法来实现。假设文件 大小为 len&#xff0c;共有 n 个进程对该文件进行拷贝。那每个进程拷贝的字节数应为 len/n。但未必一定能整除&#xff0c;我们可 以选择让…

linux下cron定时任务的总结

cron是linux系统下一个自动执行指定任务的程序&#xff0c;即包含“时间”、“路径”、“自动执行脚本”等要素 当我们要增加全局性的计划任务时&#xff0c;一种方式是直接修改/etc/crontab。但是&#xff0c;一般不建议这样做&#xff0c;/etc/cron.d目录就是为了解决这种问…

Linux系统编程---6(信号的机制,信号4要素,Linu常规信号表,定时器)

信号的概念 信号在我们的生活中随处可见&#xff0c; 如&#xff1a;古代战争中摔杯为号&#xff1b;现代战争中的信号弹&#xff1b;体育比赛中使用的信号枪… 他们都有共性&#xff1a; 简单不能携带大量信息&#xff0c;只能带一个标志。满足某个特设条件才发送。 Unix 早…

python httplib2的安装

window下python安装httplib2 https://pypi.python.org/pypi/httplib2地址下下载httplib2安装包&#xff0c;并解压缩 方法一、我的电脑->属性->高级->环境变量->系统变量 在系统变量里找到PATH&#xff0c;双击PATH&#xff0c;在结尾加上 ";C:\Python25&…

Linux系统编程----7(信号集,信号屏蔽,信号捕捉)

信号集操作函数 内核通过读取未决信号集来判断信号是否应被处理。信号屏蔽字 mask 可以影响未决信号集。而我们可以在应 用程序中自定义 set 来改变 mask。已达到屏蔽指定信号的目的。 信号集设定 sigset_t set; //typedef unsigned long sigset_t;int sigemptyset(sigset_t…

Linux系统编程----8(竞态条件,时序竞态,pause函数,如何解决时序竞态)

竞态条件(时序竞态)&#xff1a; pause 函数 调用该函数可以造成进程主动挂起&#xff0c;等待信号唤醒。调用该系统调用的进程将处于阻塞状态(主动放弃 cpu) 直 到有信号递达将其唤醒&#xff0c;等不到一直等 int pause(void); 返回值&#xff1a;-1 并设置 errno 为 EINTR…

Linux系统编程---8(全局变量异步I/O,可重入函数)

全局变量异步 I/O 分析如下父子进程交替 数数 程序。当捕捉函数里面的 sleep 取消&#xff0c;程序即会出现问题。请分析原因。 #include<stdio.h> #include<signal.h> #include<unistd.h> #include<stdlib.h>intn0,flag0; void sys_err(char* s…

http使用post上传文件时,请求头和主体信息总结

请求头必须配置如下行&#xff1a; Content-Type : multipart/form-data; boundary---12321 boundary---12321位文件的分界线 body如下&#xff1a; "-----12321\r\n" //分割文件时加-- "Content-Disposition: form-data; name\"…

iconv 文件编码转换

iconv 文件编码转换 http://qq164587043.blog.51cto.com/261469/63349 linux shell 配置文件中默认的字符集编码为UTF&#xff0d;8 。UTF&#xff0d;8是unicode的一种表达方式&#xff0c;gb2312是和unicode都是字符的编码方式&#xff0c;所以说gb2312跟utf&#xff0d;8的…

Linu系统编程---9(SIGCHLD 信号,信号传参,中断系统调用)

SIGCHLD 信号 SIGCHLD 的产生条件 子进程终止时子进程接收到 SIGSTOP 信号停止时子进程处在停止态&#xff0c;接受到 SIGCONT 后唤醒时 借助 SIGCHLD 信号回收子进程 子进程结束运行&#xff0c;其父进程会收到 SIGCHLD 信号。该信号的默认处理动作是忽略。可以捕捉该信号…

Linu系统编程---10(Linux的终端,线路规程,网络终端,进程组)

终端 输入输出设备的总称 在 UNIX 系统中&#xff0c;用户通过终端登录系统后得到一个 Shell 进程&#xff0c;这个终端成为 Shell 进程的控制终端&#xff08;Controlling Terminal&#xff09;&#xff0c; 进程中&#xff0c;控制终端是保存在 PCB 中的信息&#xff0c;而 …

PCRE函数简介和使用示例

PCRE是一个NFA正则引擎&#xff0c;不然不能提供完全与Perl一致的正则语法功能。但它同时也实现了DFA&#xff0c;只是满足数学意义上的正则。 PCRE提供了19个接口函数&#xff0c;为了简单介绍&#xff0c;使用PCRE内带的测试程序(pcretest.c)示例用法。 1. pcre_compile 原型…