woaidongmao

文章均收录自他人博客,但不喜标题前加-[转贴],因其丑陋,见谅!~
随笔 - 1469, 文章 - 0, 评论 - 661, 引用 - 0
数据加载中……

C++模版全掌握(实例)

前段时间重新学习C++,主要看C++编程思想和C++设计新思维。对模版的使用有了更进一层的了解,特总结如下:

下面列出了模版的常用情况:
//1. 模板类静态成员
template <typename T> struct testClass
{
   
static int _data;
}
;
template
<> int testClass<char>::_data = 1;
template
<> int testClass<long>::_data = 2;
int main( void ) {
    cout
<< boolalpha << (1==testClass<char>::_data) << endl;
    cout
<< boolalpha << (2==testClass<long>::_data) << endl;
}
 

//2. 模板类偏特化
template <class I, class O> struct testClass
{
    testClass()
{ cout << "I, O" << endl; } 
}
;
template
<class T> struct testClass<T*, T*> 
{
    testClass()
{ cout << "T*, T*" << endl; } 
}
;
template
<class T> struct testClass<const T*, T*> 
{
    testClass()
{ cout << "const T*, T*" << endl; } 
}
;
int main( void )
{
    testClass
<int, char> obj1;
    testClass
<int*, int*> obj2;
    testClass
<const int*, int*> obj3;
}
 

//3.类模版+函数模版
template <class T> struct testClass
{
   
void swap( testClass<T>& ) { cout << "swap()" << endl; } 
}
;
template
<class T> inline void swap( testClass<T>& x, testClass<T>& y )
{
    x.swap( y );
}
 
int main( void )
{
    testClass
<int> obj1;
    testClass
<int> obj2;
    swap( obj1, obj2 );
}
 


//4. 类成员函数模板
struct testClass
{
    template
<class T> void mfun( const T& t )
   
{
        cout
<< t << endl;
    }
 
    template
<class T> operator T()
   
{
       
return T();
    }
 
}
;
int main( void )
{
    testClass obj;
    obj.mfun(
1 );
   
int i = obj;
    cout
<< i << endl;
}
 

//5. 缺省模板参数推导
template <class T> struct test
{
    T a;
}
;
template
<class I, class O=test<I> > struct testClass
{
    I b;
    O c;
}
;

void main()
{
}



//6. 非类型模板参数
template <class T, int n> struct testClass {
    T _t;
    testClass() : _t(n)
{
    }
 
}
;
int main( void ) {
    testClass
<int,1> obj1;
    testClass
<int,2> obj2;
}
 


//7. 空模板参数
template <class T> struct testClass;
template
<class T> bool operator==( const testClass<T>&, const testClass<T>& )
{
   
return false;
}
;
template
<class T> struct testClass
{
    friend
bool operator== <>( const testClass&, const testClass& );
}
;
void main()
{
}


//8. template template 类
struct Widget1
{
template
<typename T> 
    T foo()
{} 
}
;

template
<template<class T>class X> 
struct Widget2
{
}
;
void main()
{
    cout
<< 3 << '\n';
}




//参考:http://www.cnblogs.com/dayouluo/archive/2005/05/14/155092.html

特别注意:类,全局函数,类的成员函数都可以特化,但是只有类可以半特化,全局函数和类的成员函数不可以半特化。
//-------------------------------------------
//1 类的特化和类成员函数的特化
template<typename T>
class Widget1
{
public:
   
void Fun1()
   
{
       
//generic implementation
    }

   
}
;

template
<>
class Widget1<int>
{
public:
   
void Fun1()
   
{
    }

}
;
template
<> 
void Widget1<char>::Fun1()
{
   
//specialization
}


void main()
{

  Widget1
<char> w;
  w.Fun1();
  Widget1
<int> w2;
  w2.Fun1();
 
}

//-------------------------------------------
//2 全局函数的特化和重载
template<typename T1, typename T2>
T1 Fun2(T2)
{
}


//下面2个应该是属于重载
template<typename T2>
char Fun2(T2)
{
   
char c;
   
return c;
}


template
<typename T1>
T1 Fun2(
char)
{
}


//全局函数的特化
template<>
char Fun2<char,int>(int)
{
   
char c;
   
return c;
}

int main()
{
}

//-------------------------------------------
//3 全局函数不能半特化,以下编译失败
template <typename T1,typename T2> //原型1
void Test(T1,T2)
{
}


template
<typename T1>
void Test<T1,T1>(T1,T1)
{
}


template
<typename T1, typename T2> //原型2
T1 Fun2(T2)
{
}

//
template<typename T2>
int Fun2<int,T2>(T2)
{
}

template
<typename T1>
T1 Fun2
<T1,int>(int)
{
}

template
<typename T>
T Fun2
<T,T>(T)
{
}

int main()
{
}



////-------------------------------------------
////4 类可以特化和半特化,但是特的成员函数像全局函数一样,只能特化,不能半特化,

template<typename T1, typename T2> struct Widget2
{
 
void Fun2()
 
{
     
//generic implementation
  }

}
;

template
<typename T2> 
struct Widget2<char,T2>
{
   
void Fun2()
   
{
    }

}
;

template
<typename T2>
struct widget2
{
   
void Fun2()
   
{
       
// class partial specialization
    }

}
;



//the class member funtion can not be partial specialization
//以下的成员函数半特化,编译失败
template<typename T2>
void Widget2<char, T2>::Fun2()
{
   
//class member function partial specialization
}

int main()
{
}

参考:C++编程思想2

posted on 2008-09-14 17:37 肥仔 阅读(2075) 评论(0)  编辑 收藏 引用 所属分类: C++ 模板


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理