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

            搜索

            •  

            積分與排名

            • 積分 - 53109
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

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

            到了Item18,就進(jìn)入了第四章:Designs and Declarations (其實(shí)應(yīng)該再加上“of Interfaces”)。看到標(biāo)題我猜想接下來應(yīng)該都是些大話了吧@#¥%

            因?yàn)榻涌?interface)在C++中泛濫成災(zāi),Scott認(rèn)為應(yīng)該認(rèn)真設(shè)計(jì)這些接口,使得它們:很易用對,很難用錯。
            用錯的可能有:

            • 調(diào)用接口時輸入了錯誤的參數(shù)。書中有給出例子(一個接受年、月、日為參數(shù)的接口函數(shù),用戶可以輕易給出各種錯誤的輸入),以及解決辦法:用對象來約束參數(shù)輸入的范圍(不接受簡單的整數(shù)作為輸入,而是Date、Mon、Year對象)
            • 用常規(guī)的用法調(diào)用“特別”設(shè)計(jì)的接口。所以需要盡可能的把自己的設(shè)計(jì)往常規(guī)上靠:數(shù)據(jù)對象的行為要盡可能符合內(nèi)建對象(比如int)的行為;接口的名字和意義要盡可能一致(比如STL中的容器基本都有一個叫做size的返回容器大小的接口)……這樣做鼓勵用戶去正確的看待和使用你的接口。
            • 忘了處理調(diào)用接口后的遺留問題。因此不要讓用戶去“記得”做一些事情。比如說設(shè)計(jì)一個接口返回一個指向某新建對象的指針,這樣做的結(jié)果就是該接口的用戶需要“記得”去釋放這個指針?biāo)傅膶ο螅喝绻脩敉酸尫呕蜥尫帕撕脦状危蠊褪茾#¥%
              解決的辦法之一是讓該接口返回一個智能指針(嗯……印象模糊了?去看Item14),這樣用戶用完了就可以“忘記”這個指針:它自己會處理后事。
            • 所謂的“跨DLL問題”(cross DLL problem):在一個DLL中new一個對象,然后對象被傳到另外一個DLL里被delete。大師推薦用shared_ptr因?yàn)樗鉀Q了這個問題。

            以上問題的解決也是有代價(jià)的:額外對象的創(chuàng)建和銷毀需要時間空間。比如boost的shared_ptr就是普通指針的兩倍大小,還有額外的對象操作時間+過程動態(tài)內(nèi)存分配等。應(yīng)了那句老話:有所得必有所失。實(shí)際上有些底層代碼根本沒這個資本提供這樣的“豪華裝備”,不過有這樣的思想還是很重要D……

            posted on 2009-12-31 07:55 Justin.H 閱讀(2299) 評論(3)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯

            Feedback

            # re: Effective C++ 炒冷飯 - Item18 約束接口的使用[未登錄] 2009-12-31 13:31 xu
            返回一個新建對象的指針,這...太多了,唉...  回復(fù)  更多評論
              

            # re: Effective C++ 炒冷飯 - Item18 約束接口的使用 2009-12-31 17:53 Justin.H
            # re: Effective C++ 炒冷飯 - Item18 約束接口的使用[未登錄] 2009-12-31 13:31 xu
            返回一個新建對象的指針,這...太多了,唉...

            @xu 樓上的兄臺什么太多了?為何感傷?
              回復(fù)  更多評論
              

            # re: Effective C++ 炒冷飯 - Item18 約束接口的使用 2009-12-31 21:26 羅萊家紡官方網(wǎng)
            以上問題的解決也是有代價(jià)的  回復(fù)  更多評論
              

            久久精品无码一区二区无码 | 97精品国产97久久久久久免费| jizzjizz国产精品久久| 久久久久久夜精品精品免费啦| 久久噜噜电影你懂的| 欧美粉嫩小泬久久久久久久| 综合久久一区二区三区 | 97精品依人久久久大香线蕉97| 久久婷婷五月综合色高清| 亚洲欧美精品伊人久久| 99久久精品国产一区二区| 91麻精品国产91久久久久| av色综合久久天堂av色综合在| 亚洲国产精品久久久久网站 | 国产精品青草久久久久婷婷| 蜜臀久久99精品久久久久久| 国产∨亚洲V天堂无码久久久| 亚洲&#228;v永久无码精品天堂久久 | 狠狠色丁香婷婷久久综合| a级毛片无码兔费真人久久| 久久天堂AV综合合色蜜桃网| 久久久久久毛片免费看| 久久精品成人免费看| 久久久无码精品亚洲日韩蜜臀浪潮 | 久久精品人人做人人爽97 | 国产精品久久久久天天影视| 精品久久久中文字幕人妻| 狠狠色综合网站久久久久久久| 国产情侣久久久久aⅴ免费| 亚洲中文字幕久久精品无码APP| 欧美日韩精品久久久久 | 品成人欧美大片久久国产欧美...| 香蕉久久av一区二区三区| 四虎国产精品成人免费久久| 色天使久久综合网天天 | 久久久久久久久久免免费精品| 国产精品成人99久久久久91gav| 日本精品久久久中文字幕| 91久久婷婷国产综合精品青草| 97精品国产91久久久久久| 99久久99这里只有免费的精品|