今天接到電話面試,被問到幾個問題,汗顏之余,小結(jié)一下
1、 多態(tài)是如何實現(xiàn)綁定的
多態(tài)的綁定可以分為運行是多態(tài)和編譯時多態(tài)
● 編譯時的多態(tài)性
編譯時的多態(tài)性是通過重載來實現(xiàn)的。對于非虛的成員來說,系統(tǒng)在編譯時,根據(jù)傳遞的參數(shù)、返回的類型等信息決定實現(xiàn)何種操作。
● 運行時的多態(tài)性
運行時的多態(tài)性就是指直到系統(tǒng)運行時,才根據(jù)實際情況決定實現(xiàn)何種操作。C#中,運行時的多態(tài)性通過虛成員實現(xiàn)。
編譯時的多態(tài)性為我們提供了運行速度快的特點,而運行時的多態(tài)性則帶來了高度靈活和抽象的特點。
今天才正式弄清楚原來虛函數(shù)是可以實現(xiàn)運行時多態(tài)的,以前只知道虛函數(shù)可以使得基類對象的的方法調(diào)用派生類的方法。
2、 析構函數(shù)是虛函數(shù)的優(yōu)點是什么
用C++開發(fā)的時候,用來做基類的類的析構函數(shù)一般都是虛函數(shù)。可是,為什么要這樣做呢?下面用一個小例子來說明:
有下面的兩個類:
class ClxBase
{
public:
ClxBase() {};
virtual ~ClxBase() {};
virtual void DoSomething() { cout << "Do something in class ClxBase!" << endl; };
};
class ClxDerived : public ClxBase
{
public:
ClxDerived() {};
~ClxDerived() { cout << "Output from the destructor of class ClxDerived!" << endl; };
void DoSomething() { cout << "Do something in class ClxDerived!" << endl; };
};
代碼
ClxBase *pTest = new ClxDerived;
pTest->DoSomething();
delete pTest;
輸出結(jié)果是:
Do something in class ClxDerived!
Output from the destructor of class ClxDerived!
這個很簡單,非常好理解。
但是,如果把類ClxBase析構函數(shù)前的virtual去掉,那輸出結(jié)果就是下面的樣子了:
Do something in class ClxDerived!
也就是說,類ClxDerived的析構函數(shù)根本沒有被調(diào)用!一般情況下類的析構函數(shù)里面都是釋放內(nèi)存資源,而析構函數(shù)不被調(diào)用的話就會造成內(nèi)存泄漏。我想所有的C++程序員都知道這樣的危險性。當然,如果在析構函數(shù)中做了其他工作的話,那你的所有努力也都是白費力氣。
所以,文章開頭的那個問題的答案就是--這樣做是為了當用一個基類的指針刪除一個派生類的對象時,派生類的析構函數(shù)會被調(diào)用。
當然,并不是要把所有類的析構函數(shù)都寫成虛函數(shù)。因為當類里面有虛函數(shù)的時候,編譯器會給類添加一個虛函數(shù)表,里面來存放虛函數(shù)指針,這樣就會增加類的存儲空間。所以,只有當一個類被用來作為基類的時候,才把析構函數(shù)寫成虛函數(shù)。
說實話,這個也是今天才深刻認識到的。
當然還問到很多數(shù)據(jù)結(jié)構和算法方面(空間復雜度和時間復雜度之類的東東,說真的也是基礎性的)的問題,至于那些東西,自己說實話拋開沒用他們已經(jīng)很長時間了,真可以說忘的差不多了,考這種真的很怕,也怪平時沒怎么用到。不知道大家用的多不?
好久沒有正式參加過面試了,今天突然來一次覺得自己基礎還是不夠扎實。
posted on 2008-05-19 20:30
frank.sunny 閱讀(18120)
評論(12) 編輯 收藏 引用 所屬分類:
C/C++學習和實踐