C++实现不能被继承的类实例分析
本文实例展示了C++实现不能被继承的类的方法,对于C++初学者而言有一定的学习借鉴价值。具体实现方法如下:
方法一:
#include<iostream>
usingnamespacestd;
classA
{
public:
staticA*getInstance();
staticvoiddeleteInstance(A*pA);
private:
A(){cout<<"constructA\n";}
~A(){cout<<"destructA\n";}
};
A*A::getInstance()
{
returnnewA;
}
voidA::deleteInstance(A*pA)
{
deletepA;
pA=nullptr;
}
intmain()
{
A*pA=A::getInstance();
A::deleteInstance(pA);
cin.get();
}
该方法其实就是把构造函数、析构函数private了,这样的话当想派生一个类时,派生类无法构造一个父类,所以就不行了。
方法二:
#include<iostream>
usingnamespacestd;
template<typenameT>
classA
{
friendT;
private:
A(intdata):m_data(data){cout<<"constructA.data:"<<m_data<<endl;}
~A(){}
intm_data;
};
classB:virtualpublicA<B>
{
public:
B(intdata):A(data){cout<<"constructB\n";}
~B(){}
};
intmain(void)
{
Bb(4);
cin.get();
}
类B设置为类A的友元,这样类B作为A的子类就可以构造一个父类了。这时候类B可以正常使用,但是不能从类B派生一个子类,因为B虚继承A,如果想classC:pulicB的话,由于是虚继承,那么在C类的构造函数就得直接调用A类的构造函数,但是B是A的友元,C不是,所以无法直接调用A的构造函数,编译出错。这里C类必须直接调用A的构造函数的
但是如果你把B类的声明改为classB:publicA<B>的话,那么又可以从B类派生一个子类C了,因为不用虚继承的话,在C类的构造函数调用B类的构造函数,B类的构造函数再调用A类的(B是A的友元,即使A的构造函数是private也无妨)。这是一层层向上调用的。
相信通过本文实例可以帮助大家更好的理解C++中类的原理及使用。