亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

effective c++學習筆記

發布時間:2020-10-16 05:32:08 來源:網絡 閱讀:670 作者:firekido 欄目:編程語言

--------------------1讓自己習慣c++-----------------------------------------

Rule 1 : c++看做一個語言聯邦,共有4個次語言:c(區塊、語句、預處理器、內置數據類型、數組、指針);面向對象c++(類、封裝、繼承、多態、虛函數);模板c++STL(容器、迭代器、算法以及函數對象)。當你從某個次語言切換到另一個,導致高效編程守則要求你改變策略時,不要感到驚訝。

 

Rule 2:盡量以constenuminline替換#define,盡量以編譯器代替預處理器。

 

Rule 3 盡可能使用constconst最具微力的應用是面對函數聲明時的應用:函數返回值,各參數,成員函數自身。

 

Rule 4:確定對象被使用前已先被初始化。需要關注三方面的問題:1.對內置類型意外的任何其他東西,確保每一個構造函數都將對象每一個成員初始化。2.構造函數的初值列列出的成員變量,其排列次序應該和他們在class中的聲明次序相同。3.定義于不同編譯單元的non-local static對象的初始化次序是不確定的。解決方法:將每個non-local static對象搬到自己的專屬函數內(該對象在此函數內被聲明為static

-------------------2構造/析構/賦值運算  ----------------------------------------

Rule 5:了解c++默默編寫并調用了這些函數(都是publicinline):默認構造函數,默認析構函數,復制構造函數,復制賦值操作符函數。

 

Rule 6:若不想使用編譯器自動生成的函數,就該明確拒絕。例如若不想類被復制或者賦值,就該明確拒絕,這有兩個方法。

 

Rule 7:為多態基類聲明virtual析構函數。

 

Rule 8:讓異常逃離析構函數。析構函數絕對不要吐出異常,這會導致程序可能過早結束或出現不明確的行為。如果一個被析構函數調用的函數可能拋出異常,析構函數應該捕捉任何異常,然后吞下它們(不傳播)或結束程序。

 

Rule 9:絕不在構造和析構過程中調用虛函數,這類調用從不下降至派生類。解決辦法是令派生類將必要的構造信息向上傳遞至base class構造函數。令函數為static,也就不可能意外指向初期未成熟之對象內尚未初始化的成員變量

 

Rule 10:令operator = 返回一個referenceto *this

 

Rule 11:在operator = 中處理自我賦值

 

Rule 12:復制對象時勿忘其每一個成分。

---------------------3資源管理---------------------------------------------------------

Rule 13:以對象管理資源。令資源在構造期間獲得,在析構期間釋放。

 

Rule 14:在資源管理類中小心copying行為。當一個RAII對象被復制,會有以下2種處理方式:1.禁止復制,2.對底層資源祭出引用計數法”:通常只要內含一個tr1:shared_ptr成員變量,RAIIclasses便可實現出引用計數的復制行為。

 

Rule 15:在資源管理類中提供對原始資源的訪問。

 

Rule 16:成對使用newdelete時要采用相同的形式。

 

Rule 17:以獨立語句將newed對象置入智能指針,否則可能導致資源泄露,應該將以下語句:

processWidget(std::tr1::shared_prt<Widget>(newWidget),priority());

替換為(獨立語句)

std::tr1::shared_ptr<Widget>pw(new Widget);

processWidget(pw,priority());

----------------------------4設計與聲明-------------------------------------------------------

Rule 18:讓接口容易被正確使用,不易被誤會。

 

Rule 19:設計class猶如設計type。應該和語言設計者當初設計語言內置類型時一樣謹慎地來研討class的設計。

 

Rule 20:盡量以pass-by-reference-to-const替換pass-by-value,但對內置類型,pass-by-value往往比較適當。

 

Rule 21:必須返回對象時,別妄想返回其reference

 

Rule 22:將成員變量聲明為private

 

Rule 23:寧以non-membernon-friend替換member函數。

 

Rule 24:如果需要為某個函數的所有參數(包括被this指針所指的那個隱喻參數)進行類型轉換,那個這個函數必須是個non-member

 

Rule 25:考慮寫出一個不拋出異常的swap函數。

----------------------------------------5實現------------------------------------------------------

Rule 26:盡可能延后變量定義式的出現時間,這樣可以避免構造(和析構)非必要對象。

 

Rule 27:盡量少做轉型動作。C++的集中轉型類型:

const_cast<T>(expression)  //唯一可將對象的常量性移除。

dynamic_cast<T>(expression)  //安全向下轉型

reinterpret_case<T>(expression)  //執行低級轉型

static_cast<T>(expression)  //強迫隱式轉換,例如non-const對象轉為const對象,或將int轉為double等等。

 

Rule 28:避免返回handles指向對象內部成分,這樣會破壞封裝性和const性。

應該將

Point& upperLeft() const {returnpData->ulhc;}

替換為

const Point& upperLeft() const {returnpData->ulhc;}

 

Rule 29:為異常安全而努力使值得的。

 

Rule 30:透徹了解inlining。一開始不要將任何函數聲明為inline,或至少將inlining施行范圍局限在那些一定成為inline”十分平淡無奇的函數身上。

 

Rule 31:將文件間的編譯依存關系降至最低,將接口與實現分離。一般構想是相依于聲明式,不要相依于定義式。基于此構想的2個手段是handle classesinterface classes

 

--------------------------6繼承與面向對象設計---------------------------------

Rule 32:確定你的public繼續塑模出is-a關系。

類之間的三種關系:is-ahas-ais-implemented-in-terms-of(根據某物實現出)

 

Rule 33:避免遮掩繼承而來的名稱。

如果你繼承base class并加上重載函數,而你又希望重新定義或覆寫其中一部分,那么你必須為那些原本會被遮掩的每個名稱引入一個using聲明式,否則某些你希望繼承的名稱會被遮掩。

當你不想繼承base class的所有函數,可以使用private繼承和轉交函數(什么是轉交函數?調用基類函數的函數)。

 

Rule 34:區分接口繼承和實現繼承。

 

Rule 35:考慮virtual函數以外的其他選擇。

藉由non-vitualinterface手法實現template method模式:虛函數應該幾乎總是private,令客戶通過public non-virtual成員函數間接調用private virtual函數。

藉由函數指針實現策略模式。

 

Rule 36:絕不重新定義繼承而來的non-virtual函數。

 

Rule 37:絕不重新定義繼承而來的缺省(默認)的參數值。

 

Rule 38:通過復合塑模出has-a根據某物實現出

 

Rule 39:明智而審慎地使用private繼承。如果class Dprivate形式繼承class B,則用意是為了采用classB內已經備妥的某些特性。

 

Rule 40:明智而審慎地使用多重繼承。

 

 

-----------------------7模板與泛型編程-------------------------------------------------------------------

Rule 41:了解隱式接口和編譯期多態。

classestemplates都支持接口和多態。

classes而言,接口是顯式的,以函數簽名為中心,多態則通過virtual函數發生于運行期。

template參數而言,接口是隱式的,奠基于有效表達式(如if語句內的表達式),多態則是通過template具現化和函數重載解析發生于編譯期。

 

Rule 42:了解typename的雙重意義。

 

Rule 43:學習怎么獲得基類模板中的名稱。

 

Rule 44:將與參數無關的代碼抽離templates

 

Rule 45:運用成員函數模板接受所有兼容類型。

 

Rule 46:需要類型轉換時請為模板定義非成員函數。

 

Rule 47:請使用traitsclasses表現類型信息。

 

Rule 48:認識templates元編程。

------------------------8定制newdelete------------------------------------------------------------------------

Rule 49:了解new-handler的行為。

 

Rule 50:了解newdelete的合理替換時機。

 

Rule 51:編寫newdelete時需固守常規。

 

Rule 52:寫了placementnew也要寫placement delete

 

------------------------------------9雜項討論----------------------------------------------------------------------------

Rule 53:不要輕忽編譯器的警告。

 

Rule 54:讓自己熟悉包括tr1在內的標準程序庫。

 

Rule 55:讓自己熟悉boost

 

 

 


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

灵山县| 鲁甸县| 布尔津县| 木兰县| 霞浦县| 东乌珠穆沁旗| 临高县| 静海县| 五家渠市| 福泉市| 鹤峰县| 锡林浩特市| 车险| 宜都市| 秦安县| 富裕县| 阳朔县| 武安市| 桦川县| 五指山市| 乌鲁木齐市| 龙山县| 仁寿县| 广元市| 陇川县| 夏河县| 密云县| 大兴区| 威宁| 酒泉市| 靖远县| 卢龙县| 清河县| 涞水县| 美姑县| 封丘县| 乌海市| 邻水| 文安县| 邛崃市| 密云县|