• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Note of Justin

            關于工作和讀書的筆記

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              47 Posts :: 0 Stories :: 45 Comments :: 0 Trackbacks

            留言簿(14)

            搜索

            •  

            積分與排名

            • 積分 - 52710
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創文章歡迎轉載,但請保留作者信息]

            Justin 于 2009-10-26

            這里要講的是飯前要洗手。

            如果手沒洗干凈就開動,你可能會因為吃下臟東西而腹瀉不止;如果對象沒初始化就使用,程序可能會由于未知的初值參與運算而痛苦不堪。

            道理很簡單。怎么洗呢:

            • 對于內建的對象類型(例子?int),一定要親自初始化他們,因為有時候C++不會幫你干這種沒有技術含量的活@#¥%
            • 對于對象自身的成員,推薦的方法是在構造函數的初始化列表來干這個活。
              注意,如果只是簡單的在構造函數里將變量一一賦值,那只是“賦值”,不是“初始化”。前者的效率要比后者低,因為前者先構造了對象再對他們賦值,而后者一石二鳥,畢其功于一役,在構造的同時就也把值賦了(多好的孩子!)。這里還沒加上拷貝構造函數的可能開銷,還有一些類型如const變量、引用(reference)是不能用賦值的形式“初始化”的……
              下面就有兩個程序片段的例子對比(最恨貼代碼的了,沒有一點技術含量)
              //initialize?by?assignment
              ClassA::ClassA?(int?i,?const?std::string&?s,?const?ClassC&?c)
              {
              ???iInt?
              =?i;
              ???sStr?
              =?s;
              ???cClassC?
              =?c;
              }

              // initialize?by?initialization?list
              ClassB::ClassB?( int ?i,? const ?std:: string & ?s,? const ?ClassC & ?c)
              ???:?iInt(i),
              ?????sStr(s),
              ?????cClassC(c)
              {}
            • 如果在初始化某個對象的時候,有對其他對象是否有初始化的依賴(對不起,這里有點拗口),一定要確保其中所依賴的對象已經初始化完畢。通篇幾乎都在說沒有什么技術含量,最后逼得大師給了一點有技術含量的內容:
              當不同的對象的初始化存在相互依賴時,某個對象沒有初始化有可能導致另外一個對象初始化的失敗。
              比如說,呃……我又要比如說了,吃飯前要保證做飯的自來水是干凈的,也要保證抓飯的手(哪國的?)也是干凈的。要保證手是干凈的就要洗手,洗手的前提是自來水是干凈的。這個時候手和自來水是否干凈這兩個前提之間就有了依賴關系。
              當初始化涉及到非局部靜態對象(non-local static object)時,問題更加明顯:非局部靜態對象如果定義在不同的文件中,他們就有可能位于不同的編譯單元(translation unit),因為這些對象到底誰先被初始化是不可預知的。(也就是說我們可能在洗手前并不知道水是不是已經弄干凈了)

              解決此類問題的一個方法是:把非局部靜態對象轉換為局部靜態對象(local static object),也就是把它的定義放在一個函數里。然后緊接著在這個函數返回該對象的引用。C++語言規定在調用一個含有局部靜態對象的函數時,其中的所有局部靜態對象都必須初始化。這個方法就是利用這一特性,將原本對一個非局部靜態對象的訪問,轉換為對一個函數的調用,這個函數會返回該靜態對象的引用,并且保證這個對象已經被初始化了。
              就比如說如果我們需要保證洗手的時候水已經是干凈的了,就在水龍頭外加一個凈水器,這樣只要一開水就一定是干凈的了,哇哈哈。(如果看到這里還不明白,就去看書上的例子吧,我自己也承認這一部分被我解讀得很晦澀@#¥%)

              試圖亡羊補牢,總結一下上面兩坨字:如果需要初始化一個非局部靜態對象,就把它放到一個函數里,讓這個函數簡單的返回這個對象的引用。(為什么要這樣做?你可以返回看上面兩坨字……)

            ?

            posted on 2009-12-15 21:37 Justin.H 閱讀(480) 評論(2)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯

            Feedback

            # re: Effective C++ 炒冷飯– Item 4 對象的初始化 2009-12-16 00:16 陳梓瀚(vczh)
            發布的時候有一個選項可以放到首頁的。  回復  更多評論
              

            # re: Effective C++ 炒冷飯– Item 4 對象的初始化 2009-12-16 10:09 Justin.H
            多謝提醒:)  回復  更多評論
              

            2022年国产精品久久久久 | 久久精品人人做人人爽电影| 国产午夜精品久久久久九九电影| 国产精品久久国产精品99盘| 91精品国产91久久久久久蜜臀| 久久国产视屏| 亚洲精品tv久久久久久久久| 国产精品久久久久9999| 久久精品国产色蜜蜜麻豆 | 久久久久亚洲av无码专区喷水| 免费国产99久久久香蕉| 亚洲国产精品嫩草影院久久| 久久精品国产亚洲AV无码麻豆 | 人妻中文久久久久| avtt天堂网久久精品| 欧美与黑人午夜性猛交久久久| 国产Av激情久久无码天堂| 久久中文字幕无码专区| 精品久久777| 国内精品九九久久久精品| 亚洲性久久久影院| 久久99国产精品成人欧美| 青草国产精品久久久久久| 欧美精品一区二区久久| 99热精品久久只有精品| 国产精品久久国产精品99盘| 国产亚洲精品久久久久秋霞| 久久精品国产一区二区电影| 日韩一区二区久久久久久| 国内精品久久久久影院优| 麻豆AV一区二区三区久久| 久久久久亚洲AV无码观看| 亚洲伊人久久综合影院| 欧美国产精品久久高清| 久久青青草原精品国产软件| 久久精品国产福利国产琪琪 | 狠狠色丁香婷婷久久综合 | A狠狠久久蜜臀婷色中文网| 久久久噜噜噜久久中文福利| 无码久久精品国产亚洲Av影片| 国产亚洲精品久久久久秋霞|