方法一:
#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(); } View Code其實也就是把構造函數、析構函數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(); } View Code類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也無妨)。這是一層層向上調用的。
參考:
http://see.xidian.edu.cn/cpp/biancheng/view/238.html (寫得很好)
JAVA中不能多繼承!如果你想擁有2個類的所有方法,可以采用去實現!
如:組合模式
public class A{
private B b;
private C c;
public Calc(){
b = new B();
c = new C();
}
//假如有參數的話
public Calc(String str){
b = new B(str);
c = new C(str);
}
}
有問題再追問吧,good luck!~
這句話要看怎麼理解去了,一個類不能直接繼承兩個類比如說這樣:
class A extends B,C
不能這樣寫,因為java不支持多繼承,
但是你可以像下面這樣實現繼承多個類
class A extends B
class C extends A
這樣C就同時繼承了B和A兩個類