Geekband的第一周學習的筆記整理,對於從不會做筆記的自己簡直是個試煉.過幾天會發個qt寫的象棋小游戲,排版煉字苦手。 ...
Class member Modifiers(類成員修飾詞)
public(公有):可被任何函數及類訪問
private(私有):無法被非友元的外部函數及類訪問;
protected(保護):只能夠被自身及子類訪問;
friend(友元):修飾非操作類成員,可將外部函數或類指定為操作類的友元函數(類),友元函數(類)中可直接訪問操作類中的private成員.
(PS:class的objects<實例>互為friends<友元>)
Class with pointer member(s)
class按有無成員指針可分為Class with pointer member(s)與Class without pointer member(s)兩種,前者成員指針如在使用過程中新分配了記憶體併在類生命周期結束後沒有pointer指向這個記憶體遍需要在類的析構函數中釋放這個記憶體,否則這片記憶體在程式結束前便會一直被占用,造成記憶體泄露.
(PS:pointer是數據占用記憶體的頭地址,其大小與系統的索址範圍相關32位系統中pointer占32bit即4Byte,64位則為8Byte)
Header file(頭文件)防衛式聲明
Heard file中需要進行防衛式聲明巨集定義,否則將可能導致頭文件重覆被包含,絕大多數編譯器支持
#ifndef NAME #define NAME ...... #endif
部分新版本編譯器則支持 #pragma once 的寫法.
inline function(內聯函數)
函數內聯能夠增加程式運行速度但會降低編譯速度並增加目標程式總代碼量適合用於頻繁調用且代碼短小的函數.
類結構體內聲明並定義的函數將優先內聯,class結構體外定義的函數則需要在聲明前加上inline關鍵字,函數最終是否內聯取決與函數實際代碼量與編譯器的判斷.
( PS:函數內聯實際為編譯器將函數調用跳轉替換為函數實際作用代碼,與巨集定義是兩碼事)
ctor(構造函數)與dtor(析構函數)
ctor與dtor在類生命周期開始與結束時會各被調用且只會被調用一次,預設無代碼的ctor與dtor分別執行類成員的記憶體分配與釋放,ctor可以傳入參數並重載,dtor則不行.
ctor通常指定為public,當無public的ctor時外部將無法顯示的新建實例,可通過類中public的函數得到並限制實例的創建.
(PS:dtor通常用於釋放成員指針指向記憶體)
pass by reference & return by reference
傳遞與返回參數的&(引用)通常能夠增加傳遞速度,相比傳遞任何實例時都只會傳遞實例的首地址並自動解引用.
(PS:當參數為指針類型時不能使用&)
operator overloading(操作符重載)
操作符重載聲明的方法有兩種
A:重載的操作符在類體中被聲明,聲明方式如同普通成員函數一樣,只不過他的名字包含關鍵字operator,以及緊跟其後的一個c++預定義的操作符. class perason{ bool operator > (type right);... }
B:操作符重載實現為非類成員函數(全局函數)對於全局重載操作符,代表左操作數的參數必須被顯式指定. bool operator > (type left,type right);