首页 > 其他 > 详细

STL迭代器之向量

时间:2016-10-02 23:53:31      阅读:321      评论:0      收藏:0      [点我收藏+]

当使用输入迭代器的时候,也就是直接用迭代器(指针)输入的时候一定要指定容器的大小,否则在运行时出错。可能是不指定大小就不好分配地址,就会出错吧。这都是我自己的一些猜想,很可能是错的,或不严谨。

但是在使用容器的成员函数进行写入、插入时就可以不指定向量容器大小。例如iVect.push_back(520)。

#include<iostream>
#include<vector> //包含STL向量模板头文件
#include<algorithm> //包含STL算法头文件
using namespace std;
//如果不声明命名std空间那么endl就必须写成std::endl;
//向量的定义就是std::vector<int> iVector;这就是命名空间的作用

void Display(int val)
{
cout<<val<<‘\t‘;
}
int main()
{
vector<int> iVect(4); //当不指定向量的大小的,会在运行时出错
vector<int>::iterator it = iVect.begin();
*it++ = 5;
*it++ = 2;
*it++ = 0;
*it = 1314;
for_each(iVect.begin(), iVect.end(), Display); //这是STL算法中的一个函数相当于一个循环语句
return 0;

}
技术分享

#include<iostream>
#include<vector> //包含STL向量模板头文件
#include<algorithm> //包含STL算法头文件
using namespace std;
//如果不声明命名std空间那么endl就必须写成std::endl;
//向量的定义就是std::vector<int> iVector;这就是命名空间的作用

void Display(int val)
{
cout<<val<<‘\t‘;
}
int main()
{
vector<int> iVect(4); //当不指定向量的大小的,会在运行时出错
iVect[0] = 5;
iVect[1] = 2;
iVect[2] = 0;
iVect[3] = 1314;

for_each(iVect.begin(), iVect.end(), Display); //这是STL算法中的一个函数相当于一个循环语句
return 0;
}

STL迭代器之向量

原文:http://www.cnblogs.com/emptyYPen/p/5928322.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!