C++模板的定制二:定制C++类
类模板的基本语法如下:
template <typename T>
class classname
{
……
};
T可以是任何类型,下面我就举一个类模板的例子(请大家不要追究这个类子需不需要这样写或有没有意义,记住这只是举例,我们关心的应该是语言的特性,这才是最重要的,不是吗?)。
template <typename T>
class operation
{
public:
operation(T t1,T t2):_val1(t1),_val2(t2){}
~operation(){}
T plus()
{
return _val1+_val2;
};
T minus()
{
return _val1-_val2;
};
T multiplies()
{
return _val1*_val2;
};
T divides()
{
return _val1/_val2;
};
private:
T _val1,_val2;
};
这个类封装了四则运算,如果T为用户自定义类型,那么要求必须重载’+’、’-‘、’*’、’/’运算符。但当你以如下的方式声明类对象时,你将会碰到问题,或者你不想此类型有类似的操作。
char szarr1[]="yuankai";
char szarr2[]="winmain";
operation<char*> obj2(szarr1,szarr2);
cout<<obj2.plus()<<endl; //你可能想要有不同的操作
cout<<obj2. divides()<<endl; //你可能根本就不充许有这样的操作
怎么办,当然是类定制。我们可以定制声明一个这样的类来解决这个问题。
class operation<char*>
{
public:
operation(char* t1,char* t2):_val1(t1),_val2(t2){}
~operation(){}
char* plus()
{
strcat(_val1,_val2); //这里要注意溢出
return _val1;
};
void display()
{
cout<<_val1<<endl;
cout<<_val2<<endl;
}
private:
char *_val1,*_val2;
};
这样我们再就可放心如下使用operation类了。
char szarr1[]="yuankai";
char szarr2[]="winmain";
operation<int> obj1(1,5);
operation<char*> obj2(szarr1,szarr2);
cout<<obj1.divides()<<endl;
obj2.display();
cout<<obj2.plus()<<endl;
cout<<obj2.divides()<<endl; //会编译出错,因为没有divides()函数
由些可见类模板定制可以给我们充分的控制权,就象冷酸灵牙膏广告说的一样,想怎用(吃)就怎么用(吃)。不是吗?哈哈……
了解定制函数模板使我们在使用C++类时有更大的灵活性,给我们更大更自由的空间。
文章写的仓促,有错别字或错误请大家多批评指出。欢迎和大家交流。如果大家觉的还可以我会继续写下出(-----袁凯-----)。