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

隨筆 - 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>
              欧美日韩免费观看一区三区| 国产精品日本精品| 亚洲国产精品毛片| 欧美一区激情视频在线观看| 亚洲视频一区在线| 在线中文字幕一区| 久久久女女女女999久久| 免费观看日韩av| 亚洲欧美久久| 久久精品综合网| 久久色在线播放| 久久久久久精| 噜噜噜久久亚洲精品国产品小说| 久久久久久久久久久久久女国产乱| 毛片一区二区三区| 一区二区日韩免费看| 亚洲欧美在线一区二区| 猛干欧美女孩| 国产嫩草一区二区三区在线观看| 国产一区二区三区电影在线观看| 亚洲啪啪91| 久久精品观看| 99国产精品视频免费观看| 欧美伊久线香蕉线新在线| 蜜臀av国产精品久久久久| 国产嫩草影院久久久久| 一本不卡影院| 久久嫩草精品久久久久| 亚洲在线国产日韩欧美| 欧美激情综合色| 亚洲第一天堂av| 亚洲欧美在线视频观看| 欧美日韩在线精品| 亚洲黄色成人| 免费日韩av片| 蜜桃av久久久亚洲精品| 国产一区二区三区成人欧美日韩在线观看 | 在线一区观看| 久久先锋影音av| 好吊妞**欧美| 蜜桃久久av一区| 快射av在线播放一区| 亚洲国产一区二区精品专区| 欧美成ee人免费视频| 久久婷婷成人综合色| 亚洲电影天堂av| 在线午夜精品自拍| 国产精品豆花视频| 欧美在线观看天堂一区二区三区| 亚洲一区二区在线免费观看视频 | 亚洲经典自拍| 亚洲日韩视频| 国产精品海角社区在线观看| 在线亚洲精品福利网址导航| 亚洲一区二区三区四区在线观看 | 艳妇臀荡乳欲伦亚洲一区| 亚洲综合色婷婷| 欧美一区二区三区视频在线| 国产亚洲精品bt天堂精选| 久久久爽爽爽美女图片| 欧美欧美天天天天操| 久久成人这里只有精品| 欧美日韩中文另类| 亚洲电影天堂av| 韩国美女久久| 亚洲影音先锋| 亚洲影院色无极综合| 欧美福利精品| 亚洲国产日韩欧美在线图片| 国产色产综合色产在线视频| 亚洲图色在线| 午夜精品成人在线视频| 欧美人妖在线观看| 亚洲卡通欧美制服中文| 在线综合视频| 国产精品三区www17con| 亚洲视频大全| 久久国产视频网站| 国产一区二区剧情av在线| 欧美一级大片在线免费观看| 欧美一区二区在线播放| 国语自产在线不卡| 久久精品人人做人人爽电影蜜月| 久久精品五月婷婷| 亚洲精品免费在线观看| 欧美精品在线看| 亚洲一区二区三区影院| 欧美亚洲免费| 亚洲黄色视屏| 国产精品久久久久久久免费软件| 亚洲一区二区三区免费在线观看| 久久精品盗摄| 亚洲一级片在线观看| 黄色成人片子| 国产精品久久久久久久久久久久久| 亚洲第一福利在线观看| 欧美美女bbbb| 久久久久久一区二区| 亚洲一区二区在线视频| 亚洲成在线观看| 另类激情亚洲| 欧美一区二区三区在线观看| 亚洲国产专区校园欧美| 激情国产一区| 国产欧美三级| 国产精品久久一区二区三区| 欧美精品一区三区在线观看| 久久久亚洲国产天美传媒修理工| 亚洲综合第一页| 亚洲最新色图| 亚洲视频 欧洲视频| 中日韩高清电影网| 一区二区三区不卡视频在线观看| 欧美韩日一区二区| 99www免费人成精品| 亚洲午夜精品久久| 99热免费精品| 亚洲欧美日韩成人高清在线一区| 亚洲剧情一区二区| 亚洲伊人久久综合| 午夜日韩在线| 欧美高清不卡在线| 国产精品久久久久av| 国产网站欧美日韩免费精品在线观看| 国产视频一区在线观看| 亚洲黄色三级| 亚洲性av在线| 免费国产一区二区| 男男成人高潮片免费网站| 亚洲盗摄视频| 欧美一区二区在线视频| 免费久久精品视频| 国产日韩精品一区二区三区在线| 在线欧美亚洲| 久久国产加勒比精品无码| 欧美电影资源| 99亚洲一区二区| 亚洲欧洲日产国产网站| 亚洲第一页在线| 久久精品人人做人人爽| 亚洲精品欧美日韩| 久久狠狠亚洲综合| 国产精品久久999| 日韩一级视频免费观看在线| 久久久久se| 欧美一区二区三区在线观看视频| 欧美日韩视频第一区| 影院欧美亚洲| 久久精品亚洲精品| 亚洲一区区二区| 国产乱理伦片在线观看夜一区| 日韩午夜激情av| av不卡免费看| 国产精品高清网站| 久久爱www久久做| 欧美制服丝袜| 在线观看精品| 亚洲精品美女久久7777777| 欧美伦理91i| 亚洲在线1234| 久久米奇亚洲| 亚洲精品免费在线观看| 一区二区三区不卡视频在线观看| 国产精品二区三区四区| 久久精品亚洲一区二区| 久热这里只精品99re8久| 9色porny自拍视频一区二区| 亚洲美女尤物影院| 欧美私人网站| 欧美国产一区在线| 国产精品国产| 欧美激情一区二区在线| 国产精品亚洲精品| 久久综合狠狠| 国产精品国产三级国产普通话99| 久久一区亚洲| 国产一区二区三区的电影| 亚洲欧洲日本国产| 精品福利免费观看| 亚洲欧美日韩在线观看a三区| 悠悠资源网久久精品| 久久人人爽国产| 99精品视频免费| 久久精品中文字幕免费mv| 欧美一级久久久久久久大片| 欧美大片在线看| 亚洲片国产一区一级在线观看| 国产女人18毛片水18精品| 亚洲一区观看| 欧美一级日韩一级| 国产精品一区二区三区久久| 亚洲国产aⅴ天堂久久| 亚洲激情另类| 欧美成人按摩| 在线亚洲国产精品网站| 亚洲欧美成人精品| 国产亚洲精品福利| 久久国产精品久久久| 蜜桃精品一区二区三区 | 欧美综合国产|