• <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
            謝謝提醒~
            之前有同志建議我放在主頁上,于是我就試著放在這里了。
            后面的筆記我會發布在別處的,呵呵。  回復  更多評論
              

            久久九九久精品国产| 精品熟女少妇av免费久久| 久久久久久久国产免费看| 欧美国产精品久久高清| 亚洲精品国产字幕久久不卡| 成人国内精品久久久久影院| 久久久久免费视频| 热re99久久精品国99热| 久久精品综合一区二区三区| 漂亮人妻被黑人久久精品| 国产成人香蕉久久久久| 久久久久久午夜成人影院| 久久免费大片| 99热成人精品免费久久| 久久青青草原亚洲av无码app | 国产免费久久久久久无码| 色青青草原桃花久久综合| 久久精品国产91久久综合麻豆自制 | 丁香狠狠色婷婷久久综合| 国产福利电影一区二区三区,免费久久久久久久精 | 久久国产亚洲高清观看| 一97日本道伊人久久综合影院| 久久国产成人精品麻豆| 欧美黑人激情性久久| 久久精品免费全国观看国产| 国产精品免费久久久久影院| 成人国内精品久久久久一区| 伊人久久综合无码成人网| 少妇久久久久久被弄到高潮 | 久久精品无码专区免费青青| 久久亚洲国产最新网站| 色99久久久久高潮综合影院 | 国产精品VIDEOSSEX久久发布 | 亚洲日本va中文字幕久久| 国产精品久久久久久久人人看| 国产精品亚洲综合专区片高清久久久| 人人狠狠综合久久亚洲婷婷| 久久99国产亚洲高清观看首页| 国产亚洲美女精品久久久久狼| 久久99精品国产一区二区三区| MM131亚洲国产美女久久|