青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 305651
  • 排名 - 84

最新評論

閱讀排行榜

第四章——模塊性。

模塊有兩個(gè)很重要的特性,緊湊性和正交性。
緊湊性是指小,擁有較少的public method 數(shù)量,能一次看到全貌。雖然書中提倡的10個(gè)public method 每個(gè)模塊,但是難于做到,但是15個(gè)以下,還是能做到的。
正交性是“每次只作一件事并做好”的學(xué)術(shù)詞。非正交的method的缺陷是副作用,因?yàn)樵谝淮芜^程中實(shí)現(xiàn)了兩個(gè)事情,或者更具體的說,是函數(shù)體內(nèi)實(shí)現(xiàn)了函數(shù)名說沒有說過要做的事情,并且這件事改變了模塊的狀態(tài)。舉個(gè)手頭上的例子:一個(gè)物理對象基類(IPhysxObject)有一個(gè)函數(shù)計(jì)算其子幾何體的總質(zhì)量,名稱是_computeTotalMass(dMass &mass)。我在遍歷所有幾何體算出總質(zhì)量后,把其設(shè)置為物理對象的當(dāng)前質(zhì)量——這就非正交了,因?yàn)槎嘧隽艘患拢焊淖儗ο蟮馁|(zhì)量。如果把函數(shù)名改為_updateMass(void),就沒有什么問題。
非正交帶來的副作用,雖然說目前熟悉的項(xiàng)目中沒問題,但問題是如果你有機(jī)會(huì)重用這些非正交的模塊,你很可能忘卻了它帶有副作用的地方,或者發(fā)現(xiàn)了,卻需要額外的代碼來抑制副作用。

軟件是多層的。在層的設(shè)計(jì)與實(shí)現(xiàn)過程中(自頂向下和自底向上)會(huì)出現(xiàn)膠合層。膠合層這個(gè)概念很難理解,即使現(xiàn)在仍不能說是理解正確。書上所說是“頂層邏輯和底層原語集阻抗匹配的產(chǎn)物”,軟件是通過頂層邏輯加上依賴調(diào)用底層原語的函數(shù)實(shí)現(xiàn)其功能的,那么膠合層是否可以理解為原語調(diào)用?那么,所謂的薄膠合,便是從頂層到真正的調(diào)用底層原語,其中經(jīng)歷了較少層次的函數(shù)調(diào)用嵌套。
C被視為薄膠合的語言,我看不出來(缺少根本上的代碼量);但是C++作為厚膠合的典范可是很有感觸。厚膠合源于類繼承層數(shù),即使只是兩層,仍會(huì)產(chǎn)生很普遍的麻煩,而且這其中還涉及到基類的變量是protected還是private的問題(我以前比較支持private,認(rèn)為:如果子類需要使用這些變量的話,可以在基類中添加protected的使用原語,退一步還可以添加accessor)。舉手頭上的例子:
class?Base
{
protected:
PhysxEntity??
*mpEnt;
public:
void??Touch(Base?&obj)
{?//?default?impl
mpEnt->collide(obj.mpEnt);
}

}
;

class?D1?:?public?Base
{
public:
void??Touch(Base?&obj)
{
//?other?impl
//?try?to?access?obj.mpEnt
}

}
;

class?D2?:?public?Base
{
}
;

D1?d1;
D2?d2;
d1.Touch(d2);
d1.Touch(d2),需要訪問d2的mpEnt(protected),即使是同一基類,到了子類中也是非法的。解決的辦法如友元,或者是一個(gè)public accessor,或者將D1::Touch實(shí)現(xiàn)的功能在Base中做一個(gè)原語,但是都不太舒服,不是嗎?友元者,對于數(shù)量龐大的子類間兩兩友元,需要多少心力呢?public accessor者,成員變量傳統(tǒng)上是不public的,即使accessor,如果返回成員的指針或者引用,那和直接public成員又有多少差別呢?原語者,只是把子類的功能提升到基類實(shí)現(xiàn),然后子類在寫Touch函數(shù)的時(shí)候簡單的調(diào)用原語。太多原語實(shí)現(xiàn)存放在基類,使得基類的尺寸龐大,真的好嗎?如果子類要實(shí)現(xiàn)的功能不僅涉及基類成員,還涉及子類成員,怎樣處理?作為原語引用參數(shù)傳遞,還會(huì)直觀嗎?
有點(diǎn)顯然的,accessor,或者基類原語,都不斷增加膠合的厚度,因?yàn)槟憧偸窍纫猚all一個(gè)只有一行實(shí)現(xiàn)的接口——然后才調(diào)用真正的實(shí)現(xiàn),而且真正的實(shí)現(xiàn)中,肯定還會(huì)有其他執(zhí)行類似與這種厚膠合···
厚膠合的真正缺陷并不在于函數(shù)調(diào)用效率,即使調(diào)用級數(shù)再高也不是主要問題。真正的缺陷是代碼的透明性——由于膠合過于雄厚,容易忽略某些零碎的細(xì)節(jié),bug之地難以發(fā)現(xiàn),或者code review的時(shí)候,完全沒有辦法看清全貌。
與之相比,C所以平坦,可以說是它沒有繼承(模仿會(huì)使得代碼更復(fù)雜),同時(shí),訪問完全是public的。
posted on 2006-09-10 18:48 LOGOS 閱讀(1218) 評論(2)  編輯 收藏 引用 所屬分類: 《UNIX編程藝術(shù)》讀書筆記

FeedBack:
# re: 讀《UNIX編程藝術(shù)》第四章 2006-09-10 22:51 萬連文
一直想找一本好書靜下心看,各種原因總是無法如愿。羨慕你......  回復(fù)  更多評論
  
# re: 讀《UNIX編程藝術(shù)》第四章 2006-09-11 09:45 LOGOS
呵呵。你如果時(shí)間緊張的話,每天看個(gè)3,5頁就可以了。
好書是值得慢慢看,并且多看幾遍的。  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              亚洲精品视频在线观看网站| 久久久久久久久伊人| 亚洲午夜国产一区99re久久 | 欧美在线视频观看| 欧美亚洲免费| 久久露脸国产精品| 国产真实乱偷精品视频免| 国产欧美日韩麻豆91| 狠狠入ady亚洲精品| 亚洲夫妻自拍| 亚洲视频在线二区| 久久国产手机看片| 亚洲国产精品一区二区久| 亚洲成在线观看| 欧美午夜精品久久久久久久 | 久久久www免费人成黑人精品| 欧美一级专区| 蜜桃久久av一区| 亚洲美女网站| 欧美在线视频观看| 欧美国产日韩视频| 国产精品免费在线| 亚洲人成人77777线观看| 亚洲午夜精品福利| 欧美va天堂在线| 亚洲免费婷婷| 欧美久久综合| 一区一区视频| 欧美一级理论片| 亚洲激情专区| 久久偷看各类wc女厕嘘嘘偷窃| 欧美日韩综合一区| 亚洲国产高潮在线观看| 午夜一区在线| 亚洲区欧美区| 免费欧美视频| 精久久久久久| 久久久久久精| 亚洲欧美一区二区三区久久 | 在线免费高清一区二区三区| 一区二区欧美激情| 欧美黄网免费在线观看| 小嫩嫩精品导航| 国产精品久久久久久久久| 日韩视频一区二区三区| 毛片av中文字幕一区二区| 亚洲尤物在线| 国产精品美女一区二区| 一区二区三区免费看| 欧美激情网站在线观看| 久久精品国产99国产精品| 国产女主播在线一区二区| 亚洲在线第一页| 日韩视频一区二区三区在线播放| 麻豆精品视频在线观看| 在线免费观看日本一区| 免费观看成人网| 久久久视频精品| 在线观看精品视频| 免费一区二区三区| 噜噜噜在线观看免费视频日韩 | 国产美女在线精品免费观看| 日韩性生活视频| 亚洲国产三级| 欧美激情成人在线视频| 日韩视频精品在线| 一本色道久久综合| 国产精品久久久一区二区| 午夜欧美大片免费观看| 午夜精品久久久久久久99热浪潮 | 欧美国产成人精品| 最新中文字幕一区二区三区| 欧美激情视频给我| 欧美精品网站| 亚洲欧美网站| 欧美怡红院视频一区二区三区| 国产一区二区三区在线播放免费观看| 欧美一区不卡| 久久亚洲美女| 一区二区三区欧美在线观看| 一本色道久久综合狠狠躁的推荐| 国产精品美女久久久久久免费| 香蕉视频成人在线观看| 久久精品综合一区| 亚洲精品男同| 亚洲影视在线| 亚洲大胆av| 一区二区三区欧美视频| 国产一区二区久久精品| 亚洲国产成人精品久久| 国产精品一级| 亚洲日韩视频| 国产在线拍偷自揄拍精品| 亚洲电影观看| 国产美女精品免费电影| 免费在线视频一区| 欧美亚洲成人免费| 欧美成人69av| 国产精品综合不卡av| 亚洲电影免费观看高清完整版| 国产精品毛片a∨一区二区三区| 久久男女视频| 欧美亚州在线观看| 欧美福利在线| 国产一级精品aaaaa看| 亚洲人成毛片在线播放女女| 国产日产精品一区二区三区四区的观看方式| 麻豆精品在线播放| 国产日产欧产精品推荐色| 亚洲国产色一区| 国语自产偷拍精品视频偷| 最新中文字幕一区二区三区| 国产欧美日韩激情| 亚洲精品自在在线观看| 在线观看精品一区| 欧美一区二区视频97| 亚洲网站在线观看| 欧美国产精品久久| 欧美成人国产| 国产主播精品在线| 午夜精品区一区二区三| 亚洲国产一成人久久精品| 亚欧成人在线| 亚洲网站视频| 蜜臀99久久精品久久久久久软件| 欧美一区=区| 国产精品国产自产拍高清av| 欧美岛国在线观看| 亚洲电影免费观看高清| 欧美亚洲系列| 性高湖久久久久久久久| 欧美日精品一区视频| 日韩一级在线| 正在播放亚洲一区| 欧美国产精品人人做人人爱| 欧美成人在线免费观看| 在线国产日韩| 女同一区二区| 久久婷婷成人综合色| 国产免费亚洲高清| 欧美在线综合| 欧美~级网站不卡| 亚洲高清视频的网址| 久久综合免费视频影院| 女仆av观看一区| 亚洲免费观看高清完整版在线观看熊 | 国产精品福利影院| 在线一区二区三区四区五区| 一区二区国产日产| 国产精品久久久久久久久婷婷 | 亚洲第一在线综合网站| 久久免费精品视频| 亚洲高清网站| 亚洲一区区二区| 国产精品美女久久久久久2018| 亚洲一区尤物| 玖玖玖国产精品| 最新亚洲激情| 国产精品美女一区二区在线观看| 亚洲视频在线播放| 久久久精品动漫| 亚洲黄色在线看| 欧美午夜视频在线观看| 欧美一区国产在线| 亚洲国产精品久久久久秋霞不卡 | 亚洲香蕉视频| 国产欧美一区在线| 久久在线观看视频| 99国产精品久久| 久久久蜜桃精品| 亚洲免费电影在线观看| 国产精品一区一区三区| 久久综合色8888| 亚洲小说春色综合另类电影| 久久综合综合久久综合| 一区二区三区av| 在线精品视频免费观看| 国产精品极品美女粉嫩高清在线| 久久精品欧洲| 一区二区三区欧美在线| 久久综合久久久久88| 亚洲一区三区在线观看| 在线观看的日韩av| 国产美女高潮久久白浆| 亚洲自拍偷拍视频| 亚洲精品1区| 欧美午夜一区二区三区免费大片| 亚洲欧美自拍偷拍| 亚洲精品国产日韩| 老司机一区二区| 亚洲欧美一区二区三区久久| 在线日韩中文| 国产视频在线观看一区二区三区| 欧美大片在线看| 欧美一区二区三区免费在线看| 亚洲高清电影| 免费看精品久久片| 久久精品99国产精品| 亚洲一区二区3| 亚洲每日更新|