首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 繽紛校園 英語學(xué)習(xí)
2010考研 | 自學(xué)考試 | 成人高考 | 專 升 本 | 法律碩士 | MBA/MPA | 中 科 院
四六級(jí) | 商務(wù)英語 | 公共英語 | 職稱日語 | 職稱英語 | 博思 | 口譯筆譯 | GRE GMAT | 日語 | 托福
雅思 | 專四專八 | 新概念 | 自考英語 | 零起點(diǎn)英、、韓語 | 在職申碩英語
在職攻碩英語 | 成人英語三級(jí)
等級(jí)考試 | 水平考試 | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 報(bào)檢員 | 外銷員 | 司法考試 | 導(dǎo)游考試 | 教師資格 | 國(guó)際商務(wù)師 | 跟單員
單證員 | 物流師 | 價(jià)格鑒證師 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 人力資源管理師 | 管理咨詢師
期貨從業(yè)資格 | 社會(huì)工作者
會(huì)計(jì)職稱 | 注會(huì)CPA | 經(jīng)濟(jì)師 | 統(tǒng)計(jì)師 | 注冊(cè)稅務(wù)師 | 評(píng)估師 | 精算師 | 高會(huì) | ACCA | 審計(jì)師
法律顧問 | 會(huì)計(jì)證
一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)師 | 監(jiān)理師 | 安全師 | 咨詢師 | 結(jié)構(gòu)師 | 建筑師 | 安全評(píng)價(jià)師
房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 設(shè)備監(jiān)理師 | 巖土工程師 | 質(zhì)量資格 | 房地產(chǎn)經(jīng)紀(jì)人 | 造價(jià)員
投資項(xiàng)目管理 | 土地代理人 | 環(huán)保師 | 環(huán)境影響評(píng)價(jià) | 物業(yè)管理師 | 城市規(guī)劃師 | 公路監(jiān)理師
公路造價(jià)工程師 | 招標(biāo)師
執(zhí)業(yè)護(hù)士 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 衛(wèi)生資格
您現(xiàn)在的位置: 考試吧(Exam8.com) > 軟件水平考試 > 系統(tǒng)分析師 > 正文

軟件最大的追求是什么

這段時(shí)間在開源領(lǐng)域,即將推出的Spring 2.0將支持非貧血模型,也就是說,Domain model的持久化可以干凈地全部在Domain model自身之中實(shí)現(xiàn)了,這是面向?qū)ο蠹夹g(shù)一種探索。有關(guān)域模型建模困惑可見這里。   

  當(dāng)面向?qū)ο蠹夹g(shù)正在將Model對(duì)象持久化行為綁定到Model數(shù)據(jù)自身時(shí),工業(yè)界力推的SOA則倡導(dǎo)的是將數(shù)據(jù)從行為中解耦出來。SOA相關(guān)討論見這里。看似矛盾,實(shí)際它們有一個(gè)共同點(diǎn),追求同一個(gè)終極目標(biāo):松耦合(loose coupling)。

  當(dāng)我們?cè)贘ava波濤洶涌的潮流中奮擊時(shí),我們常常會(huì)思考?我為什么要這樣做?甚至,我們會(huì)想松耦合真的那么酷?可維護(hù)性真的是軟件唯一?也許我們迷失了方向。

  我們要好好探究一下,軟件的最大追求是什么?

  我們的大學(xué)計(jì)算機(jī)教育只是教會(huì)我們?nèi)绾尉幊?這如同技工學(xué)校中教會(huì)學(xué)員如何使用車床一樣,當(dāng)我們學(xué)會(huì)了編程,接下來是什么呢?是不是就沒有了呢?是不是就是如同車工那樣只需日復(fù)一日的反復(fù)編程呢?

  其實(shí),當(dāng)你在一個(gè)系統(tǒng)中持續(xù)編程(增加新的東西),這個(gè)系統(tǒng)就變得復(fù)雜了,你面臨最大的挑戰(zhàn)是如何整理你自己的產(chǎn)物。

  也就是說:大學(xué)教育只教會(huì)我們?nèi)绾巍霸黾有碌臇|西”,但是沒有教育我們?nèi)绾巍罢磉@些東西”,而后者是目前軟件領(lǐng)域日新月異不斷發(fā)生的革命的新動(dòng)力。

  下面我們以具體代碼來說明“增加新的東西”和“整理這些東西”完全屬于不同層次的學(xué)問,有些人談到軟件只會(huì)想到算法和數(shù)據(jù)結(jié)構(gòu),認(rèn)為這些才是科學(xué),其實(shí)這是將軟件數(shù)學(xué)化,軟件不只是科學(xué)計(jì)算的工具,它自身也是一門科學(xué),更象管理學(xué)/經(jīng)濟(jì)學(xué)一樣,是科學(xué)和藝術(shù)的結(jié)合。

  在最近Java(TM) Boutique網(wǎng)站上刊登出一篇文章Measuring the Complexity of OO Systems,衡量OO系統(tǒng)的復(fù)雜性,該文對(duì)軟件復(fù)雜性幾個(gè)著名公理進(jìn)行了詳細(xì)闡述,這些公理如果你不進(jìn)行學(xué)習(xí)和培訓(xùn),即使你使用OO語言Java等這樣工具,還是顯示你是“業(yè)余”的。

  軟件復(fù)雜性包括以下部分(引自Measuring the Complexity of OO Systems):

Cyclomatic Complexity (圈復(fù)雜性) 
Response for Class (類的響應(yīng)) 
Weighted methods per class (每個(gè)類重量方法) 
Cyclomatic Complexity

  Cyclomatic Complexity可以用下面代碼來說明:

Cyclomatic Complexity (CC) = number of decision points +1 
 

  其中number of decision points是指一個(gè)if else之類的條件判斷語句,比如,是下面這個(gè)條語句:

public void isValidSearchCriteria(SearchCriteria s){

  if(s!=null) {
  return true;
  }else{
  return false;
  }
}
 

  Cyclomatic complexity 對(duì)代碼的可測(cè)試性和可維護(hù)性上有很大影響,正如上例指出,當(dāng)你要測(cè)試isValidSearchCriteria()方法 ,你必須寫三個(gè)測(cè)試用例來驗(yàn)證它。

  如果這個(gè)CC值增加,將有更多的判斷點(diǎn)(decision points)數(shù)量,也就意味著需要花費(fèi)更多的力量來測(cè)試這些方法。詳細(xì)更多說明可參考Measuring the Complexity of OO Systems一文。

  所以,if else 或while 等條件語句是對(duì)真正OO的一種傷害(這是非OO公理見Thomas McCabe),可以極端地說:一個(gè)好的OO系統(tǒng)幾乎在業(yè)務(wù)邏輯層看不到超出兩個(gè)以上條件的if else等判斷語句,這些條件語句都是可以被GoF設(shè)計(jì)模式的狀態(tài)模式/策略模式等替代(你還在用if else嗎)。

轉(zhuǎn)帖于:軟件水平考試_考試吧
文章搜索
軟件最大的追求是什么網(wǎng)友評(píng)論網(wǎng)友評(píng)論
版權(quán)聲明 --------------------------------------------------------------------------------------
    如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
 gaoxiaoliang