c++中模板_类模板的声明和定义
2017-11-17 11:24
225 查看
一、函数模板用法
1.1申明和定义
Ø 在函数申明和定义前面,加一个模板template<classT,
classC>就行,其余正常定义和申明
Ø 调用时,跟正常函数一样调用
注意:
Ø 模板在调用时,才确定参数的具体类型!!!
Ø 模板的声明或定义只能在全局,命名空间或类范围内进行。即不能在局部范围,函数内进行,比如不能在main函数中声明或定义一个模板
1.2调用示例
template<classT,
classC>
T add1(T,
T,
C);
int main()
{
add1(1, 2, 3); //只用到模板T,没有用到模板C
add1(1.5, 3.5, 3); //只用到模板T,没有用到模板C
return NULL;
}
template<classT,
classC>
T add1(T
a, T
b,C c)
{
return a +
b; //只用到模板T,没有用到模板C
}
二、类模板用法
2.1类模板的声明和定义
2.1.1类模板的申明
Ø 在类前面加一个模板template<classT,
classC>就行
2.1.2类模板的定义
Ø 在类在类前面加一个模板template<classT,
classC>
Ø 在定义类后加<T,C>。比如类A的函数Add,定义为void A<int>::Add(T a, T b)
2.1.3类模板调用
将在定义类后加<T,C>改为<int,double>
比如示例一个对象a:
A<int> a;
2.2具体示例
*.h申明
template<classT>
classA//类模板声明,类前面加template<class T>
{
public:
T a1;
int Add1(T t1,T t2);
};
*.cpp定义
//类模板声明,类前面加template<class T>。并且类A后面带这个<T>
template<classT>
intA<T>::Add1(Tt1,
T t2)
{
return t1 +t2;
}
成员函数调用
A<int> a;//实例化一个类,A后面带这个A<int>
int aa =a.Add1(2, 3);//调用模板成员函数,跟模板函数一样调用就行
三、模板类默认值设置
3.1模板类的形参为类型形参
Ø 类模板可以设置默认值,函数模板不能设置默认值
Ø 设置默认值时,尽量放在最后,不要放在开头
Ø 如果放在开头,后面一定要设置默认值,并且跟第一个默认值一样
例如:template<classT1 =
int,class
T2 =int> class
CeilDemo{…}
3.2示例
TemplateDemo03.h
#ifndefTEMPLATE_DEMO_03
#define TEMPLATE_DEMO_03
//定义带默认类型形参的类模板。这里把T2默认设置为int型。
template<classT1,
classT2 =
int>class
CeilDemo{
public:
int ceil(T1,T2);
};
//在类模板的外部定义类中的成员时template后的形参表应省略默认的形参类型。
template<classT1,
classT2>
int CeilDemo<T1,T2>::ceil(T1a,
T2 b){
return a>>
b;
}
#endif
TemplateDemo03.cpp
#include<iostream.h>
#include "TemplateDemo03.h"
void main(){
CeilDemo<int> cd;
cout <<cd.ceil(8, 2) << endl;
}
参考内容:
http://www.cnblogs.com/gw811/archive/2012/10/25/2738929.html
http://blog.csdn.net/zhongshan_c/article/details/8917470
http://blog.csdn.net/elcoteq983/article/details/7032213
1.1申明和定义
Ø 在函数申明和定义前面,加一个模板template<classT,
classC>就行,其余正常定义和申明
Ø 调用时,跟正常函数一样调用
注意:
Ø 模板在调用时,才确定参数的具体类型!!!
Ø 模板的声明或定义只能在全局,命名空间或类范围内进行。即不能在局部范围,函数内进行,比如不能在main函数中声明或定义一个模板
1.2调用示例
template<classT,
classC>
T add1(T,
T,
C);
int main()
{
add1(1, 2, 3); //只用到模板T,没有用到模板C
add1(1.5, 3.5, 3); //只用到模板T,没有用到模板C
return NULL;
}
template<classT,
classC>
T add1(T
a, T
b,C c)
{
return a +
b; //只用到模板T,没有用到模板C
}
二、类模板用法
2.1类模板的声明和定义
2.1.1类模板的申明
Ø 在类前面加一个模板template<classT,
classC>就行
2.1.2类模板的定义
Ø 在类在类前面加一个模板template<classT,
classC>
Ø 在定义类后加<T,C>。比如类A的函数Add,定义为void A<int>::Add(T a, T b)
2.1.3类模板调用
将在定义类后加<T,C>改为<int,double>
比如示例一个对象a:
A<int> a;
2.2具体示例
*.h申明
template<classT>
classA//类模板声明,类前面加template<class T>
{
public:
T a1;
int Add1(T t1,T t2);
};
*.cpp定义
//类模板声明,类前面加template<class T>。并且类A后面带这个<T>
template<classT>
intA<T>::Add1(Tt1,
T t2)
{
return t1 +t2;
}
成员函数调用
A<int> a;//实例化一个类,A后面带这个A<int>
int aa =a.Add1(2, 3);//调用模板成员函数,跟模板函数一样调用就行
三、模板类默认值设置
3.1模板类的形参为类型形参
Ø 类模板可以设置默认值,函数模板不能设置默认值
Ø 设置默认值时,尽量放在最后,不要放在开头
Ø 如果放在开头,后面一定要设置默认值,并且跟第一个默认值一样
例如:template<classT1 =
int,class
T2 =int> class
CeilDemo{…}
3.2示例
TemplateDemo03.h
#ifndefTEMPLATE_DEMO_03
#define TEMPLATE_DEMO_03
//定义带默认类型形参的类模板。这里把T2默认设置为int型。
template<classT1,
classT2 =
int>class
CeilDemo{
public:
int ceil(T1,T2);
};
//在类模板的外部定义类中的成员时template后的形参表应省略默认的形参类型。
template<classT1,
classT2>
int CeilDemo<T1,T2>::ceil(T1a,
T2 b){
return a>>
b;
}
#endif
TemplateDemo03.cpp
#include<iostream.h>
#include "TemplateDemo03.h"
void main(){
CeilDemo<int> cd;
cout <<cd.ceil(8, 2) << endl;
}
参考内容:
http://www.cnblogs.com/gw811/archive/2012/10/25/2738929.html
http://blog.csdn.net/zhongshan_c/article/details/8917470
http://blog.csdn.net/elcoteq983/article/details/7032213
相关文章推荐
- C++ - 将模板的声明和定义放置在同一个头文件里
- C++ 类模板一(类模板的定义)
- C++ - 将模板的声明和定义放置在同一个头文件里
- c++模板之声明定义分离编译模型
- C++中模板定义与声明为什么放在同一个文件中
- C++ - 将模板的声明和定义放置在同一个头文件里
- C++模板中声明和定义是否可以分开存放在.h和.cpp文件中
- C++的模板的声明和定义
- C++模板编程--模板的声明和定义
- 【c++模板】模拟实现有模板的双向链表(List)(声明和定义分离)
- c++模板声明和定义编译过程的分析
- C++模板声明定义分离编译错误详解
- C++将模板的声明和定义放置在同一个头文件里
- c++模板之声明定义分离编译模型
- C++模板编程:如何使非通用的模板函数实现声明和定义分离
- c++使用类模板时,类定义声明分离,vc编译报错
- C++模板应用——在类模板实现中引用其内部定义的复合数据类型
- C++模板 静态成员 定义(实例化)
- C++ 在头文件中声明定义字符数组或指针变量
- C++声明和定义