// Iterator-adapter_p427.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include<iostream>
#include <iterator>
#include <deque>
#include <set>
#include <vector>
#include <list>
using std::cout;
using std::cin;
using std::endl;
using std::flush;
int _tmain(int argc, _TCHAR* argv[])
{
std::ostream_iterator<int> out_it(std::cout," ");
int ia[6] = {0,1,2,3,4,5};
std::deque<int> id(ia,ia+6);
std::multiset<int> is(id.begin(),id.end());
std::vector<int> iv(is.begin(),is.end());
std::list<int> il(iv.begin(),iv.end());
std::copy(id.begin(),id.end(),out_it);//最后调用的是函数的赋值操作符,也就是说所有的输出迭代器都可以使用。
cout<<endl;
std::insert_iterator<std::multiset<int>> is_it(is,is.begin());
//std::insert_iterator<std::multiset<int>> is_it(is,is.end()); 无论什么位置,set系列的容器是使用红黑树实现,总是有序的。所以只要有insert操作的容器都可以
//前置输出
std::copy(id.begin(),id.end(),is_it);
std::copy(is.begin(),is.end(),out_it);//最后调用的是函数的赋值操作符,也就是说所有的输出迭代器都可以使用。
cout<<endl;
is.insert(10);
std::insert_iterator<std::vector<int>> iv_it(iv,iv.begin());//永远在vector最初元素0的前面插入数据,因为是一个锁定直线刚开始传值的begin,而不是动态begin,在插入之后insert_iterator会执行++操作执行0;
std::copy(is.begin(),is.end(),iv_it);//copy开始调用赋值操作
std::copy(iv.begin(),iv.end(),out_it);
cout<<endl;
std::front_insert_iterator<decltype(il)> il_it(il); //永远调用push_front去执行插入,没有位置限制,形成了倒序插入
std::copy(is.begin(),is.end(),il_it);
std::copy(il.begin(),il.end(),out_it);
cout<<endl;
//覆盖式. 5 = 0+6-1,4,3,2,1,0.如果用正序的迭代器,效果还是前面一样,是从id.end-1开始递减值begin的数据段去覆盖iv.offet-1到iv.begin的数据段
//但是我想呈现一种逆序数据的覆盖,所以使用reserve_iterator。
//std::copy_backward(id.rbegin(),id.rend(),iv.begin()+id.size());//copy_backward指的是target iterator使用backward,不是insert reserved.相应的我要处理一下。
std::copy(id.rbegin(),id.rend(),iv.begin());//++变--,但是iv是不变化的
std::copy(iv.begin(),iv.end(),out_it);
cout<<endl;
return 0;
}原文地址:http://blog.csdn.net/jingzhewangzi/article/details/41422329