vector成员转换为char输出的六种方法,STL的学习过程乱想
容器输出函数printCon测试过程中,想到的,那就是把vector
#include "stdafx.h"
#include <iostream>
#include <memory>
#include <vector>
#include "myself.h"
using namespace std;
int main()
{
vector<int> ivec;
for(int i = '1'; i <= 'z'; ++i)
ivec.push_back( i );
myself::printCon(ivec,"ASCII value: ");
//利用char类型的流迭代器输出
cout<<"ASCII type one: ";
copy( ivec.begin(),ivec.end(),ostream_iterator<char>(cout," ") );
cout<<endl;
//不知道说利用了什么,其实本质就是利用operator<<的不同重载版本
vector<char> cvec( ivec.size() ); //通过ivec的大小构建cvec再复制的方法
copy( ivec.begin(),ivec.end(),cvec.begin() );//复制到cvec后输出就自然变成char了
myself::printCon(cvec.begin(),cvec.end(),"ASCII type two: ");
//考虑到上面提及的情况,应该可以直接调用operator<<的char版本
//原理诈唬,其实不过一个强制转换
cout<<"ASCII type three: ";
vector<int>::iterator iIter;
for(iIter = ivec.begin(); iIter != ivec.end(); ++iIter)
{
cout<< static_cast<char>(*iIter)<<" ";
}
cout<<endl;
//另外,发现没有强制容器转换的操作符,没有办法,实现一个函数。
//因为不能在main里面实现,所以在最后实现,并在这里声明。
extern vector<char> ivtocv(const vector<int> &int_vec);
myself::printCon(ivtocv(ivec),"ASCII type four: ");
//当然,其实,直接利用构造函数创建也不是不可以
myself::printCon(vector<char>(ivec.begin(),ivec.end()),"ASCII type five: ");
//其实再考虑一下,不知道C++除了强制转换对象外,还有没有强制调用某重载函数的方法
//无聊之极,重载<<输出操作符试试,因为不能在main里面实现,并且不希望干扰前面的操作
//所以在最后实现,并在这里声明。
extern ostream& operator<<(ostream &os, const vector<int> &int_vec);
//如此,则可以直接输出vector<int>为char
cout<<"ASCII type five: ";
cout<<ivec;
return 0;
}
vector<char> ivtocv(const vector<int> &int_vec)
{
vector<char> char_vec; //另一种通过复制创建char_vec的方法
copy( int_vec.begin(),int_vec.end(),back_inserter(char_vec));
return char_vec;
}
ostream& operator<<(ostream &os, const vector<int> &int_vec)
{
copy( int_vec.begin(),int_vec.end(),ostream_iterator<char>(os," ") );
cout<<endl;
return os;
}
By 九天雁翎
2007年10月16日 | 九天雁翎的博客