• <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)

            搜索

            •  

            積分與排名

            • 積分 - 52711
            • 排名 - 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
            多謝提醒:)  回復  更多評論
              

            久久精品国产99国产精品| 亚洲国产成人精品无码久久久久久综合| 999久久久国产精品| 97超级碰碰碰久久久久| 欧美丰满熟妇BBB久久久| 亚洲综合精品香蕉久久网| 亚洲а∨天堂久久精品9966| 久久午夜无码鲁丝片午夜精品| 久久精品成人欧美大片| 久久久久97国产精华液好用吗| 久久97久久97精品免视看秋霞| 国内精品久久久久影院网站| 久久久中文字幕日本| 久久久无码精品亚洲日韩京东传媒| 精产国品久久一二三产区区别 | 99久久精品国产一区二区| 久久最新精品国产| 亚洲国产成人精品91久久久| 国产成人精品综合久久久久| 天天躁日日躁狠狠久久| 夜夜亚洲天天久久| 久久婷婷国产剧情内射白浆| 国产韩国精品一区二区三区久久| 午夜不卡888久久| 久久精品无码一区二区WWW| 国产精品久久国产精麻豆99网站| 久久久久亚洲AV成人网人人网站| 久久人人爽人人爽人人片AV高清| AV无码久久久久不卡蜜桃| 久久婷婷色综合一区二区| 久久国产精品无码一区二区三区| 亚洲国产精品久久久久久| 久久精品国产亚洲αv忘忧草| 蜜桃麻豆www久久| 18岁日韩内射颜射午夜久久成人| 久久最近最新中文字幕大全| 国内精品伊人久久久久妇| 精品久久久久久久久久久久久久久 | 99久久精品费精品国产| 中文字幕乱码久久午夜| 久久亚洲中文字幕精品一区四|