超越自我 從程序員到系統(tǒng)分析員
掃描二維碼
隨時(shí)隨地手機(jī)看文章
大家應(yīng)該對(duì)這兩個(gè)詞很熟悉了,但是對(duì)詞里包含的意義可能并不是特別清楚。首先必須說明的是,程序員和系統(tǒng)分析員不存在誰高級(jí)誰低級(jí)的分別,他們是兩種職業(yè),對(duì)職業(yè)技能的要求完全不同。所以厲害的程序員就是系統(tǒng)分析員的說法是不對(duì)的。當(dāng)然,系統(tǒng)分析員的技能要求他必須要懂得如何寫程序,但是他的重心在于如何把一個(gè)很大的項(xiàng)目切割成適合個(gè)人的小塊,然后將這些小塊組織起來。程序員的職責(zé)就是如何更好更快的實(shí)現(xiàn)這些小塊。
在正式開始之前,我們還是來看在Thinking In Java中作者對(duì)分析和設(shè)計(jì)的一段精辟見解:
分析和設(shè)計(jì)
面向?qū)ο蟮姆妒绞撬伎汲绦蛟O(shè)計(jì)時(shí)一種新的、而且全然不同的方式,許多人最開始都會(huì)在如何構(gòu)造一個(gè)項(xiàng)目上皺起了眉頭。事實(shí)上,我們可以作出一個(gè)“好”的設(shè)計(jì),它能充分利用OOP提供的所有優(yōu)點(diǎn)。
請(qǐng)?jiān)徳谶@里突然出現(xiàn)了OOP這個(gè)詞,他的意思是面相對(duì)象,雖然在之前沒有提到,但是在現(xiàn)在OO概念滿天飛的軟件世界里,大家應(yīng)該對(duì)他不會(huì)太陌生。這里我簡(jiǎn)要的說明一下。在之前我介紹的實(shí)際上都是在很早以前程序?qū)懽髁鱾飨聛淼慕?jīng)驗(yàn)(什么,教我們老古董,打他?。?,但是以前的非OO(就是基于過程)的軟件設(shè)計(jì)方法目前在國際上已經(jīng)很少采用,所以我這里講軟件設(shè)計(jì)的時(shí)候所有的概念都是基于OO的。即使OO的概念很簡(jiǎn)單的啦,大家思考一下,我們?cè)賹W(xué)習(xí)C++的時(shí)候一開始使用的類不都是一些動(dòng)物啦、正方形啦之類的,都是生活中的例子,對(duì)吧。其實(shí)OO就是我們看世界的一種方式??墒亲钤缬捎谟?jì)算機(jī)技術(shù)的不發(fā)達(dá),我們不得不用一些很奇怪的描述來表達(dá)我們的意思,只有這樣計(jì)算機(jī)才能理解,很笨不是嗎。比如我們必須使用參數(shù)、過程、函數(shù)。所以當(dāng)時(shí)的軟件設(shè)計(jì)方法都是基于過程的。舉一個(gè)簡(jiǎn)單的例子來顯示OO設(shè)計(jì)方法和基于過程的設(shè)計(jì)方法之間的差別:一句簡(jiǎn)單的日常短語--“我吃飯”,用OO的方法來表述還是“我吃飯”,可是如果用基于過程的方法來描述的話就變成“我吃飯(飯)”,是不是很別扭呢。
有關(guān)OOP分析與設(shè)計(jì)的書籍大多數(shù)都不盡如人意。其中的大多數(shù)書都充斥著莫名其妙的話語、笨拙的筆調(diào)以及許多聽起來似乎很重要的聲明。我認(rèn)為這種書最好壓縮到一章左右的空間,至多寫成一本非常薄的書。具有諷剌意味的是,那些特別專注于復(fù)雜事物管理的人往往在寫一些淺顯、明白的書上面大費(fèi)周章!如果不能說得簡(jiǎn)單和直接,一定沒多少人喜歡看這方面的內(nèi)容。畢竟,OOP的全部宗旨就是讓軟件開發(fā)的過程變得更加容易。盡管這可能影響了那些喜歡解決復(fù)雜問題的人的生計(jì),但為什么不從一開始就把事情弄得簡(jiǎn)單些呢?因此,希望我能從開始就為大家打下一個(gè)良好的基礎(chǔ),盡可能用幾個(gè)段落來說清楚分析與設(shè)計(jì)的問題。
不要迷失
在整個(gè)開發(fā)過程中,最重要的事情就是:不要將自己迷失!但事實(shí)上這種事情很容易發(fā)生。大多數(shù)方法都設(shè)計(jì)用來解決最大范圍內(nèi)的問題。當(dāng)然,也存在一些特別困難的項(xiàng)目,需要作者付出更為艱辛的努力,或者付出更大的代價(jià)。但是,大多數(shù)項(xiàng)目都是比較“常規(guī)”的,所以一般都能作出成功的分析與設(shè)計(jì),而且只需用到推薦的一小部分方法。但無論多么有限,某些形式的處理總是有益的,這可使整個(gè)項(xiàng)目的開發(fā)更加容易,總比直接了當(dāng)開始編碼好! 也就是說,假如你正在考察一種特殊的方法,其中包含了大量細(xì)節(jié),并推薦了許多步驟和文檔,那么仍然很難正確判斷自己該在何時(shí)停止。時(shí)刻提醒自己注意以下幾個(gè)問題:
(1) 對(duì)象是什么?(怎樣將自己的項(xiàng)目分割成一系列單獨(dú)的組件?)
(2) 它們的接口是什么?(需要將什么消息發(fā)給每一個(gè)對(duì)象?)
在確定了對(duì)象和它們的接口后,便可著手編寫一個(gè)程序。出于對(duì)多方面原因的考慮,可能還需要比這更多的說明及文檔,但要求掌握的資料絕對(duì)不能比這還少。
整個(gè)過程可劃分為四個(gè)階段,階段0剛剛開始采用某些形式的結(jié)構(gòu)。