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

            欧美丰满熟妇BBB久久久| 51久久夜色精品国产| 久久久久高潮综合影院| 久久精品免费一区二区| 72种姿势欧美久久久久大黄蕉| 欧美综合天天夜夜久久| 亚洲国产成人久久精品99| 欧美黑人又粗又大久久久| 久久本道伊人久久| 久久AV高清无码| 久久精品国产黑森林| 久久人爽人人爽人人片AV| 久久婷婷五月综合97色直播| 无码人妻少妇久久中文字幕蜜桃 | 久久久久亚洲AV成人片| 99久久亚洲综合精品成人| 亚洲中文字幕无码一久久区| 久久国产精品免费| 国产精品99久久免费观看| 日本五月天婷久久网站| 久久精品国产精品亜洲毛片| 色欲久久久天天天综合网| 综合久久精品色| 亚洲国产视频久久| 欧美国产精品久久高清| 成人午夜精品久久久久久久小说| 狠狠色婷婷久久综合频道日韩| 久久人人爽人人爽AV片| 色偷偷888欧美精品久久久| 久久99国产综合精品女同| 亚洲色婷婷综合久久| 综合网日日天干夜夜久久| 久久久久亚洲AV无码专区首JN| 人人狠狠综合88综合久久| 久久精品国产亚洲5555| 久久精品国产欧美日韩| 久久伊人影视| 97精品伊人久久久大香线蕉| 亚洲精品蜜桃久久久久久| 久久人人爽爽爽人久久久| 久久精品麻豆日日躁夜夜躁|