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

            搜索

            •  

            積分與排名

            • 積分 - 52498
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創文章歡迎轉載,但請保留作者信息]
            Justin 于 2009-12-20



            大師寫到這一章節的時候文風似有明顯轉變,原因未知,但我更喜歡這章的風格。

            如題,Item22的主旨是應該把所有類的數據成員聲明為私有(private)。因為:

            • 如果數據成員都是私有的,那么訪問這些成員就只能通過函數進行。于是用戶就不需要費心考慮到底要用什么方式去訪問數據成員:因為只有定義了的函數可以用。
            • 通過定義數據成員為私有,可以實現函數來設計、約束或禁止對這些成員的各種訪問(讀/寫等)。而如果將其設為公有(public),你將無法得知你的成員會被誰改動,也不知道會是怎樣的改動。
            • 而更重要的好處是封裝(encapsulation):可以方便的通過修改函數來改變成員的訪問方式;在成員被訪問時通知其他對象;實現多線程中的同步等等。
              封裝的好處究其本質,是通過對用戶隱藏數據成員來保證類行為的一致性(class invariant)。因為接口被成員訪問函數限制了,類的作者也為自己日后修改類的實現留了后路:如果所有的成員都是公有的,對任何代碼的修改都有可能影響到外界的使用。(因此Scott說“Public means unencapsulated, and practically speaking, unencapsulated means unchangeable, especially for classes that are widely used.”)

            那么可不可以聲明為保護(protected)呢?其實道理和前面的公有是一樣的。公有的成員對類的外部完全開放,而保護的成員對類的繼承者完全開放。這個就像兩個區間:(-infinity, +infinity) 和 (0, +infinity),兩者的大小是一樣的。

            接下來大師的一句話有擊中要害:從分裝的角度,只有兩種訪問級別:私有,及其他。

            posted on 2010-01-08 08:03 Justin.H 閱讀(1372) 評論(-1)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯

            Feedback

            # re: Effective C++ 炒冷飯 - Item22 請把數據成員聲明為私有 2010-01-08 17:13 太垃圾了
            你天天寫這東西累不?有什么用,真是無語~~順便問一句“炒冷飯”啥意思,真  回復  更多評論
              

            # re: Effective C++ 炒冷飯 - Item22 請把數據成員聲明為私有 2010-01-08 21:46 Justin.H
            以前學過的東西,重新復習。炒冷飯的意思大概就是這樣。
            為什么要寫這些在第一篇日志和標題里應該也說清楚了的,不累,真D
            至于有沒有用嘛,仁者見仁智者見智了,呵呵  回復  更多評論
              

            # re: Effective C++ 炒冷飯 - Item22 請把數據成員聲明為私有 2010-01-09 12:46 匿名
            支持樓主,我都看了,呵呵,懶得看書。  回復  更多評論
              

            # re: Effective C++ 炒冷飯 - Item22 請把數據成員聲明為私有 2010-01-20 10:08 Goteet
            那個復習吧,不過能不能別申請公布在主頁上,我們也可以通過最新隨筆找到的。  回復  更多評論
              

            # re: Effective C++ 炒冷飯 - Item22 請把數據成員聲明為私有 2010-01-20 11:32 Justin.H
            @Goteet
            謝謝提醒~
            之前有同志建議我放在主頁上,于是我就試著放在這里了。
            后面的筆記我會發布在別處的,呵呵。  回復  更多評論
              

            久久久久久精品成人免费图片 | 久久精品国产一区二区| 久久精品中文无码资源站 | 国内精品人妻无码久久久影院| 久久精品无码午夜福利理论片| 亚洲精品乱码久久久久66| 99久久综合狠狠综合久久止| 国产综合免费精品久久久| 久久久噜噜噜久久中文字幕色伊伊| 亚洲色婷婷综合久久| 久久亚洲AV永久无码精品| 无码精品久久久久久人妻中字| 国产婷婷成人久久Av免费高清 | 麻豆一区二区99久久久久| 一级做a爰片久久毛片毛片| 精品熟女少妇av免费久久| 久久精品国产亚洲Aⅴ蜜臀色欲| 亚洲精品无码久久久久去q| 精品一区二区久久| 久久香蕉超碰97国产精品| 久久播电影网| 亚洲综合婷婷久久| 久久综合综合久久97色| 国产精品久久久久久久久免费| 久久精品夜色噜噜亚洲A∨| 久久综合亚洲欧美成人| 亚洲精品tv久久久久| 国产高清美女一级a毛片久久w| 久久久精品国产sm调教网站| 久久精品国产亚洲5555| 久久久久四虎国产精品| 国产精品久久久久jk制服| 国产偷久久久精品专区| 久久婷婷色综合一区二区| 久久久久亚洲AV无码专区网站| 国产成人久久久精品二区三区| 2020久久精品国产免费| 久久国产精品99久久久久久老狼 | 亚洲中文字幕无码久久2020| 久久丫忘忧草产品| 久久久免费精品re6|