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

隨筆 - 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>
              亚洲人成高清| 欧美中文字幕不卡| 欧美高清视频在线| 欧美激情欧美激情在线五月| 亚洲国产婷婷| 一本色道久久88亚洲综合88| 欧美视频在线观看免费| 小黄鸭精品aⅴ导航网站入口| 亚洲欧美国产精品va在线观看 | 欧美一级免费视频| 亚洲黄页视频免费观看| 国产资源精品在线观看| 国产亚洲综合精品| 久久视频国产精品免费视频在线| 先锋影音久久久| 狠狠色2019综合网| 亚洲电影在线看| 欧美日韩伦理在线免费| 亚洲欧美日韩精品在线| 久久成人精品| 一区二区三区欧美激情| 亚洲女人天堂av| 亚洲激情视频在线观看| 亚洲免费一在线| 亚洲日韩视频| 欧美一区二区三区在线免费观看| 亚洲国产婷婷香蕉久久久久久| 一区二区高清| 亚洲黄色影院| 欧美亚洲一级片| 亚洲视频视频在线| 美日韩免费视频| 久久久久久精| 国产精品久久久久久久久久尿| 一本大道久久精品懂色aⅴ| 亚洲美女诱惑| 亚洲高清影视| 久久精品国产免费观看| 亚洲欧美制服中文字幕| 欧美肥婆在线| 欧美大片va欧美在线播放| 国产美女搞久久| 在线视频精品一区| 99视频精品免费观看| 久久免费视频网站| 久久人人97超碰国产公开结果| 欧美视频网站| 最新中文字幕亚洲| 亚洲精品乱码久久久久久黑人| 久久精品国产91精品亚洲| 欧美有码在线观看视频| 国产精品久久二区二区| 亚洲日本欧美在线| 亚洲精品视频免费观看| 久久一本综合频道| 免费观看亚洲视频大全| 国产午夜精品久久久久久免费视 | 蜜臀久久99精品久久久久久9| 欧美在线一区二区| 国产精品久久婷婷六月丁香| 亚洲深夜福利在线| 午夜精品福利视频| 国产精品三级久久久久久电影| 一本久久综合| 亚洲一区综合| 国产精品久久久久永久免费观看| 亚洲日韩中文字幕在线播放| 欧美日韩国产在线看| 亚洲激情自拍| 一本色道久久综合亚洲精品婷婷 | 日韩亚洲国产精品| 欧美日韩国产欧| 日韩视频免费看| 亚洲一区二区在线视频| 国产精品日韩欧美一区二区三区| 亚洲一区二区影院| 久久九九电影| 亚洲午夜黄色| 欧美在线视屏| 在线观看欧美黄色| 欧美美女日韩| 亚洲综合色婷婷| 玖玖玖国产精品| 日韩视频在线观看一区二区| 欧美午夜美女看片| 欧美在线观看网站| 亚洲片国产一区一级在线观看| 亚洲一二三区精品| 国产在线播放一区二区三区| 狂野欧美激情性xxxx欧美| 亚洲毛片在线观看| 久久久午夜精品| 日韩午夜av| 国产综合自拍| 欧美精品一区二区蜜臀亚洲| 亚洲一区二区三区精品在线| 久色成人在线| 亚洲综合视频一区| 怡红院精品视频| 欧美午夜精品久久久| 久久电影一区| 一本色道久久加勒比精品| 久久久精品国产一区二区三区 | 日韩亚洲欧美一区| 国产视频一区在线| 欧美日韩亚洲一区| 久久久久九九视频| 亚洲午夜一区二区三区| 欧美顶级艳妇交换群宴| 欧美尤物一区| 亚洲在线免费视频| 亚洲精品欧洲| 一区二区三区自拍| 国产精品视频自拍| 欧美日韩高清在线一区| 久久性色av| 久久精品2019中文字幕| 亚洲一区免费观看| 一片黄亚洲嫩模| 亚洲国内精品在线| 欧美成人午夜影院| 久久一区精品| 久久久久高清| 久久精品亚洲一区二区三区浴池| 中文日韩电影网站| 亚洲精品一二| 亚洲精品国产精品国自产观看浪潮| 国外成人免费视频| 国产亚洲精品资源在线26u| 国产精品久久久久久久久婷婷| 欧美精品免费观看二区| 久久这里只有精品视频首页| 在线一区视频| 最新精品在线| 亚洲第一精品福利| 欧美xxx在线观看| 久久在线免费观看| 久久香蕉国产线看观看网| 久久久99精品免费观看不卡| 久久精品一区二区| 久久精品女人| 久久青草久久| 欧美大片专区| 亚洲精品123区| aⅴ色国产欧美| 亚洲小视频在线观看| 午夜一区在线| 久久久久久91香蕉国产| 久热爱精品视频线路一| 欧美第一黄色网| 欧美日韩在线一区二区| 欧美视频在线一区二区三区| 国产精品国产三级国产普通话蜜臀| 国产精品av久久久久久麻豆网| 国产精品乱码妇女bbbb| 国产日韩久久| 亚洲国产精品一区在线观看不卡| 亚洲激情电影在线| 亚洲一区不卡| 久久精品一区中文字幕| 欧美成人亚洲成人| 亚洲乱码精品一二三四区日韩在线 | 亚洲午夜精品久久久久久浪潮| 亚洲天堂免费观看| 欧美在线一区二区三区| 狼人天天伊人久久| 亚洲欧洲日本mm| 亚洲永久免费精品| 久久精品在线视频| 欧美日韩亚洲一区三区| 国产欧美日韩免费看aⅴ视频| 欲色影视综合吧| 亚洲视频www| 免费精品视频| 一区二区欧美日韩| 久久久青草青青国产亚洲免观| 欧美激情精品久久久六区热门 | 欧美一区二区性| 亚洲国产视频a| 亚洲资源在线观看| 欧美freesex交免费视频| 国产精品日韩欧美一区二区| 精品电影在线观看| 香蕉成人久久| 亚洲国产欧美一区二区三区同亚洲| 亚洲伊人伊色伊影伊综合网| 麻豆精品传媒视频| 国产日韩一区| 亚洲一区在线观看免费观看电影高清| 久久人91精品久久久久久不卡| 99re热精品| 欧美高清视频一区二区| 国产亚洲精久久久久久| 中国av一区| 欧美国产欧美亚洲国产日韩mv天天看完整| 中文日韩欧美| 欧美日韩精品系列| 亚洲精品乱码久久久久久日本蜜臀| 久久激情中文| 亚洲综合视频网|