利用友元函数不能被继承的特性,可以实现这样的类
主要思想:设计一个模板辅助类Base,将构造函数声明为私有的;再设计一个不能被继承的类FinalClass,将FinalClass作为Base的友元类。将FinalClass虚继承Base。
#include <iostream>
using namespace std;
template <typename T>
class Base{
friend T;
private:
Base(){
cout << "base" << endl;
}
~Base(){}
};
class FinalClass : virtual public Base<FinalClass>{
//一定注意 必须是虚继承
public:
FinalClass(){
cout << "FinalClass()" << endl;
}
};
class C:public FinalClass{
public:
C(){} //继承时报错,无法通过编译
};
int main(){
FinalClass b; //B类无法被继承
//C c;
return 0;
}
类Base的构造函数和析构函数因为是私有的,只有Base类的友元可以访问,FinalClass类在继承时将模板的参数设置为了FinalClass类,所以构造FinalClass类对象时们可以直接访问父类(Base)的构造函数。
为什么必须是虚继承呢?
虚继承的功能是:当出现了菱形继承体系的时候,使用虚继承可以防止二义性,即子孙类不会继承多个原始祖先类。这有什么用呢?
那么虚继承如何解决这种二义性的呢?从具有虚基类的类继承的类在初始化时进行了特殊处理,在虚派生中,由最低层次的派生类的构造函数初始化虚基类
结合上面的代码来解释:C 在调用构造函数时,不会先调用FinalClass的构造函数,而是直接调用Base的构造函数,C不是Base的友元类,所以无法访问。这样的话C就不能继承FinalClass。
注:c++11的已经加入了final关键字,直接在类后面加上final关键字,就可以防止该类被继承
来源:https://blog.youkuaiyun.com/wenqiang1208/article/details/70303910