計算機二級C++常見考點分析

學識都 人氣:7.18K

C++相對衆多的面向對象的語言,具有相當高的性能。下面是小編收集的計算機二級C++常見考點分析,希望大家認真閱讀!

計算機二級C++常見考點分析

繼承與派生

1?基本概念

派生類從基類繼承了各種成員的關係就稱爲繼承。

類的繼承是新的類從已有類那裏得到已有的特性。從已有的類產生新類的過程就是類的派生。在繼承過程中,原有的類或已經存在的用來派生新類的類稱爲基類或父類,而由已經存在的類派生出的新類則稱爲派生類或子類。

從派生類的角度,根據它所擁有的基類數目不同,可以分爲單繼承和多繼承。一個類只有一個直接基類時,稱爲單繼承;而一個類同時有多個直接基類時,則稱爲多繼承。

從上面的描述可知,任何一個類都可以派生出一個新類,派生類也可以再派生出新類,因此,基類和派生類是相對而言的,一個基類可以是另一個基類的派生類,從而形成了複雜的繼承結構,出現了類的層次。基類與派生類之間的關係如下:

(1)基類是對派生類的抽象,派生類是對基類的具體化。基類抽取了它的派生類的公共特徵,而派生類通過增加信息將抽象的基類變爲某種有用的類型,派生類是基類定義的延續。

(2)派生類是基類的組合。多繼承可以看作是多個單繼承的簡單組合。

(3)公有派生類的對象可以作爲基類的對象處理。這一點與類聚集(成員對象)是不同的,在類聚集(成員對象)中,一個類的對象只能擁有作爲其成員的其他類的對象,但不能作爲其他類對象而使用。

2?派生類的定義與構成

定義派生類的一般格式如下:

class<派生類名>:<繼承方式1><基類名1>,

<繼承方式2><基類名2>,

……,

<繼承方式n><基類名n>

{

<派生類新定義成員>

};

其中,<基類名>是已有的類的名稱,<派生類名>是繼承原有類的特性而生成的新類的名稱。單繼承時,只需定義一個基類;多繼承時,需同時定義多個基類。

<繼承方式>即派生類的訪問控制方式,用於控制基類中聲明的成員在多大的範圍內能被派生類的用戶訪問。每一個繼承方式,只對緊隨其後的基類進行限定。繼承方式包括3種:公有繼承(public)、私有繼承(private)和保護繼承(protected)。如果不顯式地給出繼承方式,缺省的類繼承方式是私有繼承private。

派生類的構造函數和析構函數

1?派生類構造函數的一般格式如下:

<派生類名>::<派生類名>(<總參數表>):<基類名1>(參數表1),

……

<基類名n>(<參數表n>),

<成員對象名1>(<參數表n+1>),

……,

<成員對象名m>(<參數表n+m>)

{

<派生類構造函數體>

派生類的構造函數名與類名相同。在構造函數的參數表中,給出了初始化基類數據、成員對象數據以及新增的其他數據成員所需要的全部參數。在參數表之後,列出需要使用參數進行初始化的基類名和成員對象名以及各自的.參數名,各項之間使用逗號分隔。注意對基類成員和新增成員對象的初始化必須在成員初始化列表中進行。

當派生類有多個基類時,處於同一層次的各個基類的構造函數的調用順序取決於定義派生類時聲明的順序(自左向右),而與在派生類構造函數的成員初始化列表中給出的順序無關。如果派生類的基類也是一個派生類,則每個派生類只需負責它的直接基類的構造,依次上溯。

當派生類中有多個成員對象時,各個成員對象構造函數的調用順序也取決於在派生類中定義的順序(自上而下),而與在派生類構造函數的成員初始化列表中給出的順序無關。

建立派生類對象時,構造函數的執行順序如下:

(1)執行基類的構造函數,調用順序按照各個基類被繼承時聲明的順序(自左向右);

(2)執行成員對象的構造函數,調用順序按照各個成員對象在類中聲明的順序(自上而下);

(3)執行派生類的構造函數。

派生類的構造函數只有在需要的時候才必須定義。派生類構造函數提供了將參數傳遞給基類構造函數的途徑,以保證在基類進行初始化時能夠獲得必要的數據。因此,如果基類的構造函數定義了一個或多個參數時,派生類必須定義構造函數。

如果基類中定義了缺省構造函數或根本沒有定義任何一個構造函數(此時,由編譯器自動生成缺省構造函數)時,在派生類構造函數的定義中可以省略對基類構造函數的調用,即省略“<基類名>(<參數表>)”。成員對象的情況與基類相同。

當所有的基類和成員對象的構造函數都可以省略,並且也可以不在成員初始化列表中對其他數據成員進行初始化時,可以省略派生類構造函數的成員初始化列表。

2?派生類的析構函數

與構造函數相同,派生類的析構函數在執行過程中也要對基類和成員對象進行操作,但它的執行過程與構造函數嚴格相反,即:

(1)對派生類新增普通成員進行清理。

(2)調用成員對象析構函數,對派生類新增的成員對象進行清理。

(3)調用基類析構函數,對基類進行清理。

派生類析構函數的定義與基類無關,與沒有繼承關係的類中的析構函數的定義完全相同。它只負責對新增普通成員的清理工作,系統會自己調用基類及成員對象的析構函數進行相應的清理工作。