开发者

C++中的模板类继承和成员访问问题

目录
  • C++模板类继承和成员访问
  • 类、类模板的protected成员(受保护)继承规则
    • 小结一下

Candroid++模板类继承和成员访问

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 <&ljavascriptt; endl;
 }
};

模板函数的内部类继承时,也是类似的。

例如:

template<typename T>
class o编程uter
{
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:
	
};

编译时报错如下:

C++中的模板类继承和成员访问问题

原因是派生类只能继承类,而不能继承类模板,解决措施就是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) { }//添加了一行使用继承开发者_Go教程自基类的protected成员的语句
};

编译时报错如下:

C++中的模板类继承和成员访问问题

原因在于,派生类只能访问具体某个类的protected成员,不能访问一个模板的protected成员。

testi未指定究竟是继承自哪个类的protected成员,解决措施措施如下:

(1)如果想访问的是继承自D0类的testi成员,则修改如下:

//基类模板
template<typename T>
class D0 {
protected:
	int testi;
	double testdouble;
};
//派生类模板
template<typename T>
class D1 :public androidD0<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成员。

以上为个人经验,希望能给大编程客栈家一个参考,也希望大家多多支持我们。

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜