C++完成不克不及被繼續的類實例剖析。本站提示廣大學習愛好者:(C++完成不克不及被繼續的類實例剖析)文章只能為提供參考,不一定能成為您想要的結果。以下是C++完成不克不及被繼續的類實例剖析正文
本文實例展現了C++完成不克不及被繼續的類的辦法,關於C++初學者而言有必定的進修自創價值。詳細完成辦法以下:
辦法一:
#include <iostream>
using namespace std;
class A
{
public:
static A* getInstance();
static void deleteInstance(A* pA);
private:
A() { cout << "construct A\n";}
~A() { cout << "destruct A\n"; }
};
A* A::getInstance()
{
return new A;
}
void A::deleteInstance(A* pA)
{
delete pA;
pA = nullptr;
}
int main()
{
A* pA = A::getInstance();
A::deleteInstance(pA);
cin.get();
}
該辦法其實就是把結構函數、析構函數private了,如許的話當想派生一個類時,派生類沒法結構一個父類,所以就不可了。
辦法二:
#include <iostream>
using namespace std;
template <typename T>
class A
{
friend T;
private:
A(int data) : m_data(data) { cout << "construct A. data: " << m_data << endl; }
~A() {}
int m_data;
};
class B : virtual public A<B>
{
public:
B(int data) : A(data) { cout << "construct B\n"; }
~B() {}
};
int main(void)
{
B b(4);
cin.get();
}
類B設置為類A的友元,如許類B作為A的子類便可以結構一個父類了。這時候候類B可以正常應用,然則不克不及從類B派生一個子類,由於B虛繼續A,假如想 class C : pulic B 的話,因為是虛繼續,那末在C類的結構函數就得直接挪用A類的結構函數,然則B是A的友元,C不是,所以沒法直接挪用A的結構函數,編譯失足。這裡C類必需直接挪用A的結構函數的
然則假如你把B類的聲明改成 class B : public A<B> 的話,那末又可以從B類派生一個子類C了,由於不消虛繼續的話,在C類的結構函數挪用B類的結構函數,B類的結構函數再挪用A類的(B是A的友元,即便A的結構函數是private也不妨)。這是一層層向上挪用的。
信任經由過程本文實例可以贊助年夜家更好的懂得C++中類的道理及應用。