C++中模板类的输入输出流重载函数实现
2012-12-30 20:47
375 查看
(转)C++模板类中操作符重载之"<<"和">>"重载
2011-01-10 17:05:31| 分类:IT与程序 | 标签:
|字号大中小 订阅
在模板类中输入流“》”和输出流“《”的重载,若使用友元在类内声明,在类外实现,那么连接时将会报错,但我们可以采用以下三种方式来实现输出流"<<"和"输入流>>"的重载。
一、将输出流"<<"和"输入流>>"重载的实现写在类中
#include "stdafx.h"
#include <iostream>
using namespace std;
template<class T>
class Test
{
public:
Test(const T& t):data(t){}
//---------------------------------------------
friend ostream& operator<<(ostream& out,Test<T>& t) //输出流重载声明及实现
{
return out<<"data is "<<t.data;
} //--------------------------------------------
friend istream& operator>>(istream& in,Test<T>& t) //输入流重载声明及实现
{
return in>>t.data;
}//---------------------------------------------
private:
T data;
};//-----------------------------------------------------------------
int main()
{
Test<int> b(3);
cout<<b<<'\n';
cin>>b;
cout<<b<<'\n';
return 0;
}
那么输入输出流重载为什么不能在类内声明,类外实现呢??因为模板比较特殊,若果在模板类外实现重载的话:
template<class T>
ostream& operator<<(ostream& out,Test<T>& t)
{
return out<<"data is "<<t.data;
} //--------------------------------------------
上面正好是函数模板的定义,而我们知道操作符重载函数不是类的成员函数,因此此处相当于定义了一个新的函数模板(不同于类中的friend ostream& operator<<(ostream& out,Test<T>& t) )。但若去掉template<class T> ,函数中的参数Test<T>就不知是什么类型,所以不能在模板类内声明,类外实现操作符重载。
二、既然类外实现相当于重定义了一个函数模板,那么只要他不使用类的私用成员即可,因此重载的函数模板只有通过类的公有成员函数来实现对类的私有成员的操作,这样不必在类内声明它为友元,直接在类外重载即可。
#include "stdafx.h"
#include <iostream>
using namespace std;
template<class T>
class Test
{
public:
Test(const T& t):data(t){}
T GetData()const{return data;}
void SetData(T &item){data=item;}
private:
T data;
};//-----------------------------------------------------------------
template<class T>
ostream& operator<<(ostream& out,Test<T>& t)
{
return out<<"data is "<<t.GetData();
} //--------------------------------------------
template<class T>
istream& operator>>(istream& in,Test<T>& t)
{
T item;
in>>item;
t.SetData(item);
return in;
}//---------------------------------------------
int main()
{
Test<int> b(3);
cout<<b<<'\n';
cin>>b;
cout<<b<<'\n';
return 0;
}
三、使用过渡函数
#include "stdafx.h"
#include <iostream>
using namespace std;
template<class T>
class Test
{
public:
Test(const T& t):data(t){}
//---------------------------------------------
template<class CharT,class CharTraits>
basic_ostream<CharT,CharTraits>& Output(basic_ostream<CharT,CharTraits>& out)const //输出流过渡函数
{
return out<<"data is "<<data;
} //--------------------------------------------
template<class CharT,class CharTraits>
basic_istream<CharT,CharTraits>& Input(basic_istream<CharT,CharTraits>& in) //输入流过渡函数
{
return in>>data;
}//---------------------------------------------
private:
T data;
};//-----------------------------------------------------------------
template<class T,class CharT,class CharTraits>
basic_ostream<CharT,CharTraits>& operator<<(basic_ostream<CharT,CharTraits>& out,const Test<T>& t) //输出流重载
{
return t.Output(out);
}//------------------------------------------------------------------
template<class T,class CharT,class CharTraits>
basic_istream<CharT,CharTraits>& operator>>(basic_istream<CharT,CharTraits>& in,Test<T>& t) //输入流重载
{
return t.Input(in);
}//------------------------------------------------------------------
int main()
{
Test<int> b(4);
cout<<b<<'\n';
cin>>b;
cout<<b<<'\n';
return 0;
}
相关文章推荐
- C/C++--模板类实现.h和.cpp分离
- C++模板类头文件和实现文件分离的方法(vs2012测试)
- 单链表的C++实现(采用模板类)
- 数据结构-栈:顺序栈与链栈的C++模板类实现
- C++之STL(二):实现简单容器模板类Vec(vector capacity 增长问题、allocator 内存分配器)
- C++模板类实现顺序表
- 链表的顺序表示和实现(C++模板类实现)
- 数据结构之栈(链式存储)——C++模板类实现
- 用C++编写递归函数GetPower(int x,int y)计算x的y次幂,在同一程序里中针对整型和实型实现两个重载的函数;在主程序中实现输入输出
- 基于pthread的C++阻塞队列模板类的实现
- vector模板类的C++实现
- c++模板类递归实现二叉搜索树及其基本操作
- c++ 模板类实现 动态顺序表 基础操作
- 数据结构之循环队列(顺序表存储)——C++模板类实现
- 堆结构的C++模板类实现
- [C++]模板类的声明与实现分离问题
- C++中的链表节点用模板类和用普通类来实现的区别
- C++顺序列表的实现(采用模板类)
- 数据结构-链表逆置(c++模板类实现)
- C++模板类实现“堆”的经典案例学习+(优先队列)