下了一个开源的线程库zthread,2.3.2版本的,有错,在linux下不 能编译通过,疯,后来改了点代码才编译过。
后来找到了原因:
代码里用到了模板继承,当子类和父类都是模板类时,子类函数调用父类的函数时(不管是模板函数还是非模板函数)需要在所掉函数前面加上父类名字的限制,比如:
template <class T>
class B
{
// 模板函数
T getB(){........}
// 非模板函数
int getI(){........}
}
template <class T1,class T2>
class D public : B<T1>
{
T1 getDB()
{
return getB();
}
int getDI()
{
return getI();
}
}
这样就不会编译通过,如果把D的实现代码该为如下就没问题了
template <class T1,class T2>
class D public : B<T1>
{
T1 getDB()
{
return B <T1>::getB();
}
int getDI()
{
return B <T1>::getDI();
}
}
关于 模板使用时应注意的:
类模板的定义和实现必须在类内,而不 能在类外,自然就更不能说
是.h来声明.cpp来实现了
后来找到了原因:
代码里用到了模板继承,当子类和父类都是模板类时,子类函数调用父类的函数时(不管是模板函数还是非模板函数)需要在所掉函数前面加上父类名字的限制,比如:
template <class T>
class B
{
// 模板函数
T getB(){........}
// 非模板函数
int getI(){........}
}
template <class T1,class T2>
class D public : B<T1>
{
T1 getDB()
{
return getB();
}
int getDI()
{
return getI();
}
}
这样就不会编译通过,如果把D的实现代码该为如下就没问题了
template <class T1,class T2>
class D public : B<T1>
{
T1 getDB()
{
return B <T1>::getB();
}
int getDI()
{
return B <T1>::getDI();
}
}
关于 模板使用时应注意的:
类模板的定义和实现必须在类内,而不 能在类外,自然就更不能说
是.h来声明.cpp来实现了