探討C++中不能聲明為虛函數(shù)的有哪些函數(shù)
常見的不不能聲明為虛函數(shù)的有:普通函數(shù)(非成員函數(shù));靜態(tài)成員函數(shù);內聯(lián)成員函數(shù);構造函數(shù);友元函數(shù)。
1.為什么C++不支持普通函數(shù)為虛函數(shù)?
普通函數(shù)(非成員函數(shù))只能被overload,不能被override,聲明為虛函數(shù)也沒有什么意思,因此編譯器會在編譯時邦定函數(shù)。
多態(tài)的運行期行為體現(xiàn)在虛函數(shù)上,虛函數(shù)通過繼承方式來體現(xiàn)出多態(tài)作用,頂層
函數(shù)不屬于成員函數(shù),是不能被繼承的
2.為什么C++不支持構造函數(shù)為虛函數(shù)?
這個原因很簡單,主要是從語義上考慮,所以不支持。因為構造函數(shù)本來就是為了明確初始化對象成員才產生的,然而virtual function主要是為了再不完全了解細節(jié)的情況下也能正確處理對象。另外,virtual函數(shù)是在不同類型的對象產生不同的動作,現(xiàn)在對象還沒有產生,如何使用virtual函數(shù)來完成你想完成的動作。(這不就是典型的悖論)
(1)構造函數(shù)不能被繼承,因而不能聲明為virtual函數(shù)
(2)構造函數(shù)一般是用來初始化對象,只有在一個對象生成之后,才能發(fā)揮多態(tài)
作用,如果將構造函數(shù)聲明為virtual函數(shù),則表現(xiàn)為在對象還沒有生成的情
況下酒使用了多態(tài)機制,因而是行不通的。
3.為什么C++不支持內聯(lián)成員函數(shù)為虛函數(shù)?
其實很簡單,那內聯(lián)函數(shù)就是為了在代碼中直接展開,減少函數(shù)調用花費的代價,虛函數(shù)是為了在繼承后對象能夠準確的執(zhí)行自己的動作,這是不可能統(tǒng)一的。(再說了,inline函數(shù)在編譯時被展開,虛函數(shù)在運行時才能動態(tài)的邦定函數(shù))
inline函數(shù)和virtual函數(shù)有著本質的區(qū)別,inline函數(shù)是在程序被編譯時就展開,在函數(shù)調用處用整個函數(shù)體去替換,而virtual函數(shù)是在運行期才能夠確定如何去調用的,因而inline函數(shù)體現(xiàn)的是一種編譯期機制,virtual函數(shù)體現(xiàn)的是一種運行期機制。此外,一切virtual函數(shù)都不可能是inline函數(shù)。
4.為什么C++不支持靜態(tài)成員函數(shù)為虛函數(shù)?
這也很簡單,靜態(tài)成員函數(shù)對于每個類來說只有一份代碼,所有的對象都共享這一份代碼,他也沒有要動態(tài)邦定的必要性。不能被繼承,只屬于該類。
5.為什么C++不支持友元函數(shù)為虛函數(shù)?
因為C++不支持友元函數(shù)的繼承,對于沒有繼承特性的函數(shù)沒有虛函數(shù)的說法。友元函數(shù)不屬于類的成員函數(shù),不能被繼承。
eg:
/*
* main.cpp
*
* Author: china
*/
#include <iostream>
using namespace std;
class B {
public:
B() {
cout << "基類構造" << endl;
}
/*在類的繼承中,如果有基類指針指向派生類,那么用基類指針delete時,如果不定義成虛函數(shù),派生類中派生的那部分無法析構。
* 你可以吧virtual去掉試一下
* 因此在類的繼承體系中,基類的析構函數(shù)不聲明為虛函數(shù)容易造成內存泄漏。所以如果你設計一定類可能是基類的話,必須要聲明其為虛函數(shù)。
* */
virtual ~B() {
cout << "基類析構" << endl;
}
virtual void func() {
cout << "基類的func()" << endl;
}
private:
};
class D :public B{
public:
D() {
cout << "派生類構造" << endl;
}
~D() {
cout << "派生類析構" << endl;
}
void func() {
cout << "派生類的func()" << endl;
}
private:
};
int main(int argc, char **argv) {
D d; //調用構造先有對象
B*p = &d;
p->func(); //再體現(xiàn)多態(tài)機制
p = new D(); //再調用構造
p->func(); //再體現(xiàn)多態(tài)機制
delete p;
return 0;
}
以上就是小編為大家?guī)淼奶接慍++中不能聲明為虛函數(shù)的有哪些函數(shù)全部內容了,希望大家多多支持腳本之家~
相關文章
C++用指針變量作為函數(shù)的參數(shù)接受數(shù)組的值的問題詳細總結
以下是對C++中用指針變量作為函數(shù)的參數(shù)接受數(shù)組的值的問題進行了詳細的總結介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10
C++集體數(shù)據(jù)交換實現(xiàn)示例講解
這篇文章主要介紹了C++集體數(shù)據(jù)交換實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2022-11-11

