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

            關(guān)于工作和讀書的筆記

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

            留言簿(14)

            搜索

            •  

            積分與排名

            • 積分 - 53108
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創(chuàng)文章歡迎轉(zhuǎn)載,但請保留作者信息]
            Justin 于 2009-12-23

            先從23條規(guī)說起,大師在一開始先給出了為什么推崇非成員函數(shù)的理由:

            • 從面向?qū)ο蟮慕嵌葋砜矗浅蓡T函數(shù)更有利于數(shù)據(jù)的封裝。
              數(shù)據(jù)的封裝程度可以這樣理解:一個數(shù)據(jù)成員被越少的代碼訪問到,該成員的封裝程度就越高。我們可以進一步這樣理解:越少函數(shù)可以直接訪問一個數(shù)據(jù)成員,該成員的封裝程度就越高。
              如果還記得22課的內(nèi)容,就知道類的數(shù)據(jù)成員應該定義為私有。如果這個前提成立,那么能夠訪問一個數(shù)據(jù)成員的函數(shù)便只能是該類的成員函數(shù),或是友元函數(shù)。
              于是很容易得到上面的結(jié)論:為了更好的封裝數(shù)據(jù),在可以完成相同功能的前提下,應該優(yōu)先考慮使用非成員并且非友元函數(shù)。
              這里的“非成員并且非友元函數(shù)”是針對數(shù)據(jù)成員所在的類而言的,也就是說這個函數(shù)完全可以是其他類的成員,只要是不能直接訪問那個數(shù)據(jù)成員就可以。
            • 從靈活性上來說,非成員函數(shù)更少編譯依賴(compilation dependency),也就更利于類的擴展。
              先援引大師的例子來說明一下怎樣是編譯依賴:一個類可能有多個成員函數(shù),可能有一個函數(shù)需要A.h,另外一個函數(shù)要包含B.h,那么在編譯這個類時就需要同時包含A.h和B.h,也就是說該類同時依賴兩個頭文件。
              如果我們使用的是非成員函數(shù)咧,這個時候就可以把這些依賴關(guān)系不同的函數(shù)分別寫在不同的頭文件中,有可能這個類在編譯時就不需要再依賴A.h或是B.h了。
              另外一點要注意的是在把這些非成員函數(shù)分散定義在不同頭文件中的同時,需要用namespace關(guān)鍵字把它們和需要訪問的類放在一起。(好歹有點關(guān)系,別不住在一起就翻臉不認人了嘛……)
              //?code?in?class_a.h
              namespace??AllAboutClassA??{
              ???
              class??ClassA??{?//?..};
              ???
              //?..
              }

              //?code?in?utility_1.h
              //?..
              namespace??AllAboutClassA??{
              ???
              void??WrapperFunction_1()?{?//?..};
              ???
              //?..
              }
              //?..

              //?code?in?utility_2.h
              //?..
              namespace??AllAboutClassA??{
              ???
              void??WrapperFunction_2()?{?//?..};
              ???
              //?..
              }
              //?..

              這樣一來,雖然這些非成員和類不“住在”一個頭文件里,它們的“心”還是在一起的(在同一個名字空間, namespace, 中)。
              如果有需要添加新的非成員函數(shù),我們要做的只是在相同的名字空間中定義這些函數(shù)就可以,那個類絲毫不會被影響,也即所謂的易擴展性吧。
              對于類的用戶來說,這樣的實現(xiàn)方式(指用非成員函數(shù))就更加合理:
              因為作為類的用戶,需要擴展類的時候又不能去修改別人的類(版權(quán)?安全性?或者根本就沒有源碼?),就算是通過繼承該類的方式也不能訪問父類的私有數(shù)據(jù)。
            接下來看看第24條,說的也是非成員非友元函數(shù)。Item24的標題比較不直白:”當類型轉(zhuǎn)換需要應用在所有參數(shù)的時候,函數(shù)應該是非成員函數(shù)“,讀下來覺得還是無法理解。【以下是自己對此條軍規(guī)的解讀,有待再次拜讀時完善】代碼在書上,很好很明了。不抄代碼了,嘗試總結(jié)一下:
              如果運算符函數(shù)的參數(shù)有可能發(fā)生類型轉(zhuǎn)換,該函數(shù)就應該定義為非成員非友元函數(shù)。原因是:
              此類函數(shù)幾乎總是隱性調(diào)用的:
              result?=?oneHalf?*?2;?//?*?is?invoked?implicitly
              而鮮少有下面的顯性調(diào)用:
              result?=?oneHalf.operator*(2);?//?*?is?invoked?explicitly
              當操作數(shù)對象的類型沒有定義這一運算符函數(shù)時(或是沒有定義隱性構(gòu)造函數(shù), implicit constructor時),就會出錯。
              如果不明白,就去看例程吧……
            posted on 2010-01-11 08:23 Justin.H 閱讀(1561) 評論(0)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯
            麻豆精品久久久久久久99蜜桃| 色天使久久综合网天天| 日本免费一区二区久久人人澡| 久久亚洲精品视频| 久久精品无码一区二区WWW| 2021少妇久久久久久久久久| 国产成人精品久久亚洲| 一本色道久久88—综合亚洲精品| 国产一级做a爰片久久毛片| 三级韩国一区久久二区综合| www久久久天天com| 久久精品国产乱子伦| 伊人色综合久久| 国产亚洲精久久久久久无码| 伊人久久大香线蕉精品不卡| 91久久精品无码一区二区毛片| 97精品国产97久久久久久免费 | 香蕉99久久国产综合精品宅男自 | 伊人色综合久久| 无码伊人66久久大杳蕉网站谷歌| 人人狠狠综合久久亚洲88| 久久国语露脸国产精品电影| 久久精品国产国产精品四凭| 久久亚洲高清观看| 2020久久精品国产免费| 久久久久99精品成人片欧美| 77777亚洲午夜久久多喷| 久久综合亚洲色一区二区三区| 久久无码精品一区二区三区| 久久成人国产精品一区二区| 久久AAAA片一区二区| 久久精品国产亚洲Aⅴ香蕉| 国内精品久久久久影院网站| 国产成人香蕉久久久久| 精品国产乱码久久久久久浪潮 | 久久996热精品xxxx| 亚洲午夜久久影院| 久久久久国产一级毛片高清板 | 亚洲va久久久久| 久久无码中文字幕东京热| 一本久久知道综合久久|