目录
- C++模板类继承和成员访问
- 类、类模板的protected成员(受保护)继承规则
C++模板类继承和成员访问
c++中声明一个模板类及子类,在子类中如果需要访问父类的protected变量,需要使用父类的类作用域限定符,否则会报“identifier not found”错误。
例如:
template<typename T>
class A
{
protected:
int a;
};
template<typename T>
//模板的继承,基类需要指定模板参数
class B : public A<T>
{
public:
void func()
{
//此处必须使用A::a来访问;否则会找不到a的定义
//如果不是模板类,显然可以直接使用a来访问
cout << A::a << endl;
}
};
模板函数的内部类继承时,也是类似的。
例如:
template<typename T>
class outer
{
public:
class innerBase
{
protected:
T a;
};
//在模板类内部继承相同范围内的基类,基类能指定模板参数(内部类默认使用外部类的模板参数)
//如果继承其他的模板类,则需要指定模板参数;内部类也可以定义自己的模板参数
class innerDrive : public innerBase
{
public:
void func()
{
//此处必须使用innerBase::a(或者使用outer::innerBase::a)来访问a
//否则无法找到a的定义
cout << innerBase::a << endl;
}
};
};
类、类模板的protected成员(受保护)继承规则
如下,为基类模板和派生类模板的继承层次:
//基类模板
template<typename T>
class D0 {
protected:
int testi;
double testdouble;
};
//派生类模板
template<typename T>
class D1 :public D0 {
public:
};
编译时报错如下:

原因是派生类只能继承类,而不能继承类模板,解决措施就是D0后添加模板类型参数,如下:
//基类模板
template<typename T>
class D0 {
protected:
int testi;
double testdouble;
};
//派生类模板
template<typename T>
class D1 :public D0<T> {//修改处,D0后增加了<T>
public:
};
现在开始在派生类中使用继承自基类的protected成员:
//基类模板
template<typename T>
class D0 {
protected:
int testi;
double testdouble;
};
//派生类模板
template<typename T>
class D1 :public D0<T> {
public:
D1():testi(0) { }//添加了一行使用继承自基类的protected成员的语句
};
编译时报错如下:

原因在于,派生类只能访问具体某个类的protected成员,不能访问一个模板的protected成员。
testi未指定究竟是继承自哪个类的protected成员,解决措施措施如下:
(1)如果想访问的是继承自D0类的testi成员,则修改如下:
//基类模板
template<typename T>
class D0 {
protected:
int testi;
double testdouble;
};
//派生类模板
template<typename T>
class D1 :public D0<T> {
public:
D1():D0<int>::testi(0) { }//访问继承自D0<int>的protected成员
};
(2)如果是想访问跟随实例化D1的类型T,则修改如下:
//基类模板
template<typename T>
class D0 {
protected:
int testi;
double testdouble;
};
//派生类模板
template<typename T>
class D1 :public D0<T> {
public:
D1():D0<T>::testi(0) { }//如果D1被实例化时为D1<int>,那么就访问继承自D0<int>的protected成员
//如果D1被实例化时为D1<doublie>,那么就访问继承自D0<double>的protected成员
//如果D1被实例化时为D1<string>,那么就访问继承自D0<string>的protected成员
//…………………………………………
};
(2.1)也就是说T会跟随实例化D1模板的类型而变化。
小结一下:
(1)派生类不能直接使用基类模板的protected成员,必须指定是使用
具体哪个基类的protected成员。