c++知識點面向對象_第1頁
c++知識點面向對象_第2頁
c++知識點面向對象_第3頁
c++知識點面向對象_第4頁
c++知識點面向對象_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費閱讀

付費下載

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

c++知識點面向對象c++面對對象重點整理

1、OOP概述

面對對象基于三個根本概念:數據抽象、繼承和動態(tài)綁定。通過運用數據抽象,我們可以將類的接口與實現分別;運用繼承,可以定義相像的類型并對其相像關系建模;運用動態(tài)綁定,可以在必須程度上忽視相像類型的區(qū)分,而以統(tǒng)一的方式運用它們的對象。

1.1繼承

繼承是派生類與基類之間的關系,它們共享了一些公共的東西,而派生類特化了一些本質不同的東西。類與類之間的繼承關系構成了繼承層次。在C++中,基類必需指定盼望派生類重定義哪些函數,定義為virtual的函數是基類期盼派生類重新定義的,須要在派生類中繼承的不能定義為虛函數。

派生類重新定義的虛函數前面可以加virtual,但這不是必要的,在C++11中,允許派生類顯式地注明它將運用哪個成員函數改寫基類虛函數,只用在該函數形式參數列表后增加一個override關鍵字。

1.2動態(tài)綁定

當函數接口定義了基類的引用(或指針)時,在函數內調用虛函數時,發(fā)生動態(tài)綁定。因為這時候函數實參可以為基類類型也可以為派生類類型,虛函數只有在運行階段才能確定須要調用哪個定義。

2、定義基類與派生類

2.1定義基類

基類成員函數中盼望在派生類中重新定義的函數前面加了virtual,這類函數在調用時,在程序運行階段確定。任何構造函數之外的非靜態(tài)函數都可以是虛函數。virtual關鍵字只須要在基類定義的時候加在須要重定義的函數前面,實現的時候不須要。

基類通常都應當定義一個虛析構函數,即使該函數不執(zhí)行任何實際操作也是如此。

派生類可以繼承定義在基類中的成員,但是派生類的成員函數不能訪問從基類繼承而來的private成員,只能訪問public和protected成員。而用戶那么只能通過派生類訪問從基類繼承而來的public成員。

pubic:用戶可訪問的類成員,繼承類也可以訪問它們。

private:類的成員和友元可以訪問,繼承類不能訪問。

protected:用戶不能訪問,但是可以被類的成員或派生類的成員訪問。

2.2定義派生類

1)派生類的成員變量分兩種:一是從基類繼承到的成員變量,另一種是顯示自己特別化的變量或者為特別化接口而打算的變量。

2)一般來說派生類都要重新定義基類中聲明的虛函數,但假如沒有重新定義,那么延用基類里的定義。

3)派生類中的虛函數定義與基類應當完全相同,假如基類返回基類類型的引用,派生類那么返回派生類類型的引用。

4)派生類中定義虛函數時,可以不保存virtual。

5)作為基類的類必需是已經定義的,不能僅僅是聲明,因為它的成員將被用到,所以一個類不能從自身派生出一個類。

2.3virtual與其他成員函數

發(fā)生動態(tài)綁定的兩個條件:

1)虛函數

2)基類類型的引用或指針進展函數調用

在任何須要基類的地方都可以用派生類對象去代替,所以指向基類的指向或引用可以指向派生類,因為派生類有全部它須要的成員或成員函數。

對象是非多態(tài)的對象類型確定且不變。對象的動態(tài)類型是與靜態(tài)類型一樣,這一些與引用或指針相反。運行的函數是由對象的類型定義的。

假如派生類須要調用虛函數的基類版本,那么須要用作用域操作符來覆蓋虛函數機制。

不要在基類和派生類中為虛函數定義不同的默認實參,因為實參是靜態(tài)綁定的,在編譯時期確定,所以當你用指向派生類對象的基類類型的指針訪問虛函數時,事實上用的是基類成員函數的默認實參。

2.4訪問限制與繼承

派生列表中運用訪問標號用來確定運用派生類的用戶和對基類成員訪問的權限。

首先,基類中只有public和protected的成員可以被派生類訪問。

1)假如派生類是公用繼承(publicinheritance)

派生類的成員或友員可以訪問基類中的public和protected成員,用戶通過派生類可以訪問基類中的public成員,基類中的private只有基類的成員可以訪問。

classBulk_item:publicItem_base{...};

那么基類中的public與protected就像派生類中的public和protected類型一樣。

2)假如派生類是受愛護繼承(protectedinheritance)

classBulk_item:protectedItem_base{...};

基類中的public和protected成員就像派生類的中protected一樣

3)假如派生類是私有繼承(privateinheritance)

classBulk_item:privateItem_base{...};

基類中的public和protected成員就像派生類的中private一樣,用戶不能通過派生類對象訪問基類中的任何成員。

public派生類繼承了基類的接口,可以在須要基類的地方運用public派生類。而private和protected派生類那么不行以。

可以用using聲明復原基類成員在派生類中的訪問級別。

class和struct在定義繼承類的,默認的繼承類別也不同。

classBase{...};

classD1:Base{...}等價于classD1:privateBase{...}

structD2:Base{...}等價于classD2:publicBase{...}

class與struct用來定義類除了訪問級別的不同外,其他沒有任何不同。

派生類的成員函數中不能干脆訪問基類類型對象的protected成員,但是可以通過派生類對象訪問基類的protected成員。

voidBulk_item::memfcn(constBulk_itemd,constItem_baseb)

{

//priceisprotected

doubleret=price;//ok

ret=d.price;//ok

ret=b.price;//error

}

2.5繼承與靜態(tài)成員

假如基類定義了static成員,那么在整個繼承層次中只有一個這樣的成員。

2.6防止繼承的發(fā)生

有時候我們會定義這樣一種類,我們不盼望其他類繼承它,或者不想考慮它是否適合作為一個基類。C++11中允許在類名后加一個關鍵字final來防止繼承。

ClassNoDerivedfinal{/**/}

ClassBad:publicNoDerived{/**/}//error!

3、派生類與基類之間的轉換

可以將基類的指針或引用綁定到派生類對象上有一層極為重要的含義:當運用基類的引用(或指針)時,事實上我們并不清晰該引用(或指針)所綁定對象的真實類型。該對象可能是基類的對象,也可能是派生類的對象。

3.1靜態(tài)類型與動態(tài)類型

表達式的靜態(tài)類型在編譯時總是確定的,它是變量聲明時的類型或表達式生成的類型;動態(tài)類型那么是變量或表達式表示的內存中的對象的類型,動態(tài)類型直到運行才可知。假如表達式既不是引用也不是指針,那么它的動態(tài)類型恒久與靜態(tài)類型相同。

3.2派生類轉換為基類

引用轉換不同于對象轉換

1)將派生類對象傳遞給盼望承受基類引用的函數,事實上傳遞進去的就是原來的派生類對象,這個對象沒有發(fā)生任何改變。

2)而假如將派生類對象傳遞給盼望承受基類對象的函數,事實上是將實參派生類對象中基類局部復制出來,創(chuàng)立了一個臨時的基類對象。

3)派生類對象轉換為基類對象事實上像是做了裁切操作。

3.3基類轉換為派生

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論