c++中如何使用类模板
答案:2 悬赏:0 手机版
解决时间 2021-03-20 01:45
- 提问者网友:聂風
- 2021-03-19 13:46
在VC2010中添加是添加类还是新建项?
最佳答案
- 五星知识达人网友:廢物販賣機
- 2021-03-19 15:02
template<typename T>//方法模板
T add(T const&a,const T&b){//两个const限定等价
return a+b;
}//注意,这里没有分号,因为这是方法
template<typename T>//结构体模板
struct S{
T s;
};//注意,这里有分号,因为这是结构体
template<typename T>//类模板
class A{
public:
S<T> s;//使用了结构体模板
void set(T s0);
};//注意,这里有分号,因为这是类
template<typename T>//实现类里面的方法
void A<T>::set(T s0){//注意这一行的格式
s.s=s0;
}
//注意,这个方法只有到被使用时才会开始实例化,不过可以显式实例化让它一开始就实例化
int main(){
template A<int>;//显式实例化
template A<double>;
int a=1,b=2;
double c=3.3;
add(a,b);//正确
add(a,c);//错误,模板参数类型是严格匹配的,不可能进行隐式转换
A<int> a;//使用了类模板
a.set(5);
cout<<a.s.s;//输出5
}
以上为类型参数模板
下面为值参数模板
template<unsigned int N>
class bitset;
。。。
bitset<100> b1;
模板定做,即针对某一类型的参数特别处理,比如加法并不是对所有的类型都适用,对于char*类型就要定做下
//先定义模板
template<typename T>
class A{
public:
T s;
void show();
}
template<typename T>
void A<T>::show(){
cout<<s<<endl;
}
//然后模板定做
class B{}//定义一个类型
template<>//不要填入类型
class A<B>{//直接使用自己需要的类型
public:
B s;//相应改为自己需要的类型
void show();
}
void A<B>::show(){//注意格式,这里没有template语句
cout<<s<<endl;
}
模板参数可以有多个
template<typename T1,typename T2>
class A{}
只定做T2而不定做T1就叫局部定做,如:
template<typename T1>
class A<T1,T1>{}
或
template<typename T1>
class A<T1,B>{}
T add(T const&a,const T&b){//两个const限定等价
return a+b;
}//注意,这里没有分号,因为这是方法
template<typename T>//结构体模板
struct S{
T s;
};//注意,这里有分号,因为这是结构体
template<typename T>//类模板
class A{
public:
S<T> s;//使用了结构体模板
void set(T s0);
};//注意,这里有分号,因为这是类
template<typename T>//实现类里面的方法
void A<T>::set(T s0){//注意这一行的格式
s.s=s0;
}
//注意,这个方法只有到被使用时才会开始实例化,不过可以显式实例化让它一开始就实例化
int main(){
template A<int>;//显式实例化
template A<double>;
int a=1,b=2;
double c=3.3;
add(a,b);//正确
add(a,c);//错误,模板参数类型是严格匹配的,不可能进行隐式转换
A<int> a;//使用了类模板
a.set(5);
cout<<a.s.s;//输出5
}
以上为类型参数模板
下面为值参数模板
template<unsigned int N>
class bitset;
。。。
bitset<100> b1;
模板定做,即针对某一类型的参数特别处理,比如加法并不是对所有的类型都适用,对于char*类型就要定做下
//先定义模板
template<typename T>
class A{
public:
T s;
void show();
}
template<typename T>
void A<T>::show(){
cout<<s<<endl;
}
//然后模板定做
class B{}//定义一个类型
template<>//不要填入类型
class A<B>{//直接使用自己需要的类型
public:
B s;//相应改为自己需要的类型
void show();
}
void A<B>::show(){//注意格式,这里没有template语句
cout<<s<<endl;
}
模板参数可以有多个
template<typename T1,typename T2>
class A{}
只定做T2而不定做T1就叫局部定做,如:
template<typename T1>
class A<T1,T1>{}
或
template<typename T1>
class A<T1,B>{}
全部回答
- 1楼网友:傲气稳了全场
- 2021-03-19 16:23
template//方法模板t add(t const&a,const t&b){//两个const限定等价 return a+b;}//注意,这里没有分号,因为这是方法template//结构体模板struct s{ t s;};//注意,这里有分号,因为这是结构体template//类模板class a{ public: s s;//使用了结构体模板 void set(t s0);};//注意,这里有分号,因为这是类template//实现类里面的方法void a::set(t s0){//注意这一行的格式 s.s=s0;}//注意,这个方法只有到被使用时才会开始实例化,不过可以显式实例化让它一开始就实例化int main(){ template a;//显式实例化 template a; int a=1,b=2; double c=3.3; add(a,b);//正确 add(a,c);//错误,模板参数类型是严格匹配的,不可能进行隐式转换 a a;//使用了类模板 a.set(5); cout
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯