#include "stdafx.h"
#include <iostream>
using namespace std;
template <class T>
class CFinalClass
{
friend T;
private:
CFinalClass(){}
~CFinalClass(){}
};
class CXX
{
public:
CXX(){ cout << "I am CXX!"<<endl;}
~CXX(){}
};
class CParent:virtual public CFinalClass<CParent>,public CXX
{
public:
CParent(){}
~CParent(){}
};
class CChild:public CParent{};
int _tmain(int argc, _TCHAR* argv[])
{
CParent p;
//CChild c;
return 0;
#include <iostream>
using namespace std;
template <class T>
class CFinalClass
{
friend T;
private:
CFinalClass(){}
~CFinalClass(){}
};
class CXX
{
public:
CXX(){ cout << "I am CXX!"<<endl;}
~CXX(){}
};
class CParent:virtual public CFinalClass<CParent>,public CXX
{
public:
CParent(){}
~CParent(){}
};
class CChild:public CParent{};
int _tmain(int argc, _TCHAR* argv[])
{
CParent p;
//CChild c;
return 0;
}
利用c++中的友元类的特性----友元不能被继承
还需要强调一下,调用CFinalClass类,一定要虚继承。虚继承的一个特征就是虚基类的构造函数由最终子类负责构造!
本文通过一个C++示例介绍了如何使用友元类特性和虚继承来控制类的构造过程。重点在于理解友元类不能被继承的特性及虚继承中虚基类构造函数的调用机制。
347

被折叠的 条评论
为什么被折叠?



