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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

gtl_csdn   2022-11-26 我要评论

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成员。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们