構造方法用來初始化類的物件,與父類的其它成員不同,它不能被子類繼承(子類可以繼承父類所有的成員變數和成員方法,但不繼承父類的構造方法)。因此,在建立子類物件時,為了初始化從父類繼承來的資料成員,系統需要呼叫其父類的構造方法。
如果沒有顯式的建構函式,編譯器會給乙個預設的建構函式,並且該預設的建構函式僅僅在沒有顯式地宣告建構函式情況下建立。
構造原則如下:
1. 如果子類沒有定義構造方法,則呼叫父類的無引數的構造方法。
2. 如果子類定義了構造方法,不論是無引數還是帶引數,在建立子類的物件的時候,首先執行父類無引數的構造方法,然後執行自己的構造方法。
3. 在建立子類物件時候,如果子類的建構函式沒有顯示呼叫父類的建構函式,則會呼叫父類的預設無參建構函式。
4. 在建立子類物件時候,如果子類的建構函式沒有顯示呼叫父類的建構函式且父類自己提供了無參建構函式,則會呼叫父類自己的無參建構函式。
5. 在建立子類物件時候,如果子類的建構函式沒有顯示呼叫父類的建構函式且父類只定義了自己的有參建構函式,則會出錯(如果父類只有有引數的構造方法,則子類必須顯示呼叫此帶參構造方法)。
6. 如果子類呼叫父類帶引數的構造方法,需要用初始化父類成員物件的方式,比如:
#include
class
animal…};
class
fish:
public animal…};
void
main
()
在fish類的建構函式後,加乙個冒號(:),然後加上父類的帶引數的建構函式。這樣,在子類的建構函式被呼叫時,系統就會去呼叫父類的帶引數的建構函式去構造物件。
例外像mfc常見的cdialog繼承可以看到這種例子..
標頭檔案中
#pragma once
class
cdrugdlg :
public cdialogex
;protected:
virtual
void
dodataexchange
(cdataexchange* pdx)
;
// ddx/ddv 支援
declare_message_map()
public:
afx_msg void
onsize
(uint ntype, int cx, int cy)
;
virtual bool oninitdialog();
afx_msg void
onpaint();
afx_msg void
ondestroy();
};
實現檔案
// drugdlg.cpp : 實現檔案
//#include
"stdafx.h"
#include
"medical.h"
#include
"drugdlg.h"
#include
"afxdialogex.h"
// cdrugdlg 對話方塊
implement_dynamic(cdrugdlg, cdialog)
cdrugdlg::cdrugdlg(cwnd* pparent
/*=null*/)
:cdialogex(cdrugdlg::idd, pparent)
cdrugdlg::~cdrugdlg()
這種初始化方式,還常用來對類中的常量(const)成員進行初始化,如下面的**所示:
class
point
;
當然,類中普通的成員變數也可以採取此種方式進行初始化,然而,這就沒有必要了..
在C 中子類繼承和呼叫父類的建構函式方法
構造方法用來初始化類的物件,與父類的其它成員不同,它不能被子類繼承 子類可以繼承父類所有的成員變數和成員方法,但不繼承父類的構造方法 因此,在建立子類物件時,為了初始化從父類繼承來的資料成員,系統需要呼叫其父類的構造方法。如果沒有顯式的建構函式,編譯器會給乙個預設的建構函式,並且該預設的建構函式僅僅...
在C 中子類繼承和呼叫父類的建構函式方法
360 圖書館 2011 09 24 09 30 構造方法用來初始化類的物件,與父類的其它成員不同,它不能被子類繼承 子類可以繼承父類所有的成員變數和成員方法,但不繼承父類的構造方法 因此,在建立子類物件時,為了初始化從父類繼承來的資料成員,系統需要呼叫其父類的構造方法。如果沒有顯式的建構函式,編譯...
在C 中子類繼承和呼叫父類的建構函式方法
構造方法用來初始化類的物件,與父類的其它成員不同,它不能被子類繼承 子類可以繼承父類所有的成員變數和成員方法,但不繼承父類的構造方法 因此,在建立子類物件時,為了初始化從父類繼承來的資料成員,系統需要呼叫其父類的構造方法。如果沒有顯式的建構函式,編譯器會給乙個預設的建構函式,並且該預設的建構函式僅僅...