一種簡(jiǎn)單有效的面向過(guò)程軟件設(shè)計(jì)思想
引 言
本文引用地址:http://butianyuan.cn/article/88826.htm 面向狀態(tài)轉(zhuǎn)換的軟件設(shè)計(jì)思想屬于面向過(guò)程軟件設(shè)計(jì)思想的范疇,它完全符合軟件工程模塊化、結(jié)構(gòu)化的設(shè)計(jì)思想。在面向過(guò)程的軟件設(shè)計(jì)中,狀態(tài)的轉(zhuǎn)化與分解對(duì)于解決具有復(fù)雜過(guò)程的問(wèn)題有著很好的效果,并能被用戶很好地理解和接受,它的基本指導(dǎo)思想為:自頂向下、逐層分解、逐步求精、理清狀態(tài)、分解狀態(tài)。同時(shí),它也具有很強(qiáng)的實(shí)用性、可讀性、可移植性,并且思路清晰、簡(jiǎn)單易學(xué)、具有一定范圍內(nèi)的通用性。通??刹捎肬ML中的狀態(tài)圖來(lái)對(duì)其進(jìn)行設(shè)計(jì)和描述,也可使用有窮自動(dòng)機(jī)(DFA)中的狀態(tài)圖來(lái)對(duì)其進(jìn)行設(shè)計(jì)和描述。
1 單過(guò)程對(duì)象狀態(tài)轉(zhuǎn)換圖
首先,來(lái)看一個(gè)簡(jiǎn)單的單過(guò)程對(duì)象的例子。在洗衣機(jī)的工作過(guò)程中,一般要經(jīng)過(guò)以下幾個(gè)過(guò)程:
?、俳油娫?,洗衣機(jī)按“啟動(dòng)”按鈕后開始供水;
?、诋?dāng)水滿到“水滿傳感器”時(shí)就停止供水;
?、鬯疂M之后,洗衣機(jī)開始執(zhí)行漂洗過(guò)程,正轉(zhuǎn)5 s,然后倒轉(zhuǎn)5 s,執(zhí)行此循環(huán)動(dòng)作10 min;
?、芷唇Y(jié)束之后,出水閥開始放水;
?、莘潘?0 s后結(jié)束放水;
?、揲_始脫水操作,脫水持續(xù)5 min;
?、呙撍Y(jié)束后發(fā)出“光報(bào)警器”報(bào)警,叫工作人員來(lái)取衣服;
⑧按“停止”按扭(或10 s報(bào)警超時(shí)到),聲光報(bào)警器停止,并結(jié)束整個(gè)工作過(guò)程。
按照該洗衣機(jī)的工作流程,可用有窮自動(dòng)機(jī)(DFA)中的狀態(tài)圖來(lái)描述其狀態(tài)轉(zhuǎn)化過(guò)程,如圖1所示。
了解了該洗衣機(jī)的狀態(tài)轉(zhuǎn)化過(guò)程后,根據(jù)其狀態(tài)轉(zhuǎn)化圖就可以很容易地為其進(jìn)行軟件設(shè)計(jì),并寫出相應(yīng)的程序?qū)崿F(xiàn)代碼。
2 單過(guò)程對(duì)象狀態(tài)轉(zhuǎn)換圖的程序代碼實(shí)現(xiàn)
下面就根據(jù)該洗衣機(jī)工作狀態(tài)轉(zhuǎn)換圖,對(duì)洗衣機(jī)工作過(guò)程進(jìn)行軟件設(shè)計(jì)和編程(使用C語(yǔ)言來(lái)描述):
首先,該狀態(tài)圖只涉及一個(gè)對(duì)象,那就是洗衣機(jī),因此只需要定義一個(gè)狀態(tài)變量,用該狀態(tài)變量來(lái)表示洗衣機(jī)的狀態(tài)。該變量定義為:
最后,再定義一個(gè)時(shí)間變量wDelayTime來(lái)表示對(duì)洗衣機(jī)工作過(guò)程中的時(shí)間控制。至此,通過(guò)洗衣機(jī)工作過(guò)程中的狀態(tài)轉(zhuǎn)換圖,就可以很容易地寫出該洗衣機(jī)工作過(guò)程的程序?qū)崿F(xiàn)代碼(函數(shù)StateControl(),其中有些函數(shù)的具體實(shí)現(xiàn)代碼沒(méi)有給出,主要目的是要了解該狀態(tài)轉(zhuǎn)換的設(shè)計(jì)思想和方法)。
3 多過(guò)程對(duì)象狀態(tài)轉(zhuǎn)換圖
再來(lái)看一個(gè)相對(duì)比較復(fù)雜的問(wèn)題,在程控電話交換機(jī)中,一臺(tái)程控電話交換機(jī)可接有上百、上千,甚至上萬(wàn)部電話機(jī)。其中,每一部電話機(jī)對(duì)應(yīng)于程控電話交換機(jī)中的一個(gè)物理及邏輯端口,程控電話交換機(jī)就是通過(guò)對(duì)這些物理及邏輯端口的工作狀態(tài)進(jìn)行控制,進(jìn)而實(shí)現(xiàn)對(duì)這些電話機(jī)工作狀態(tài)的控制。一部正常工作的電話機(jī)一般具有以下幾種主要狀態(tài):空閑態(tài)、撥號(hào)態(tài)、回鈴音態(tài)、振鈴態(tài)、通話態(tài)和忙音態(tài)。程控電話交換機(jī)的工作過(guò)程主要就是實(shí)現(xiàn)電話機(jī)在這些狀態(tài)之間的轉(zhuǎn)換與遷移。
由于連接在一臺(tái)程控電話交換機(jī)上的所有電話機(jī)都具有上述6個(gè)相同的狀態(tài)轉(zhuǎn)換過(guò)程,因此,可用一個(gè)狀態(tài)數(shù)組來(lái)表示一臺(tái)程控電話交換機(jī)上所有電話機(jī)的工作狀態(tài)。圖2為程控電話交換機(jī)中電話機(jī)工作時(shí)的狀態(tài)轉(zhuǎn)換圖。
4 多過(guò)程對(duì)象狀態(tài)轉(zhuǎn)換圖的程序代碼實(shí)現(xiàn)
為在軟件設(shè)計(jì)及程序代碼上實(shí)現(xiàn)上述程控電話交換機(jī)中電話機(jī)狀態(tài)的轉(zhuǎn)移,首先需要定義6種工作狀態(tài)(用C語(yǔ)言實(shí)現(xiàn)):
還要注意到,在撥號(hào)狀態(tài),還存在2種子狀態(tài):聽(tīng)撥號(hào)音撥首位號(hào)狀態(tài)和聽(tīng)靜音撥非首位號(hào)狀態(tài)。
也就是說(shuō),在撥首位號(hào)時(shí)是處于聽(tīng)撥號(hào)音狀態(tài)的撥號(hào),而在撥非首位號(hào)時(shí)則是處于聽(tīng)靜音狀態(tài)的撥號(hào),這兩種狀態(tài)是要進(jìn)行區(qū)分的。當(dāng)然,首位號(hào)在程控電話交換機(jī)中還有其他更為重要的作用,這里就不多講了。
為此,需為撥號(hào)態(tài)再定義2種子狀態(tài),定義如下:
假設(shè)該程控電話交換機(jī)最多可接有1 000部電話機(jī),由于這些電話機(jī)都具有上述6種狀態(tài),并且都具有相同的狀態(tài)轉(zhuǎn)移過(guò)程,因此,可用一個(gè)狀態(tài)數(shù)組來(lái)表示所有電話機(jī)的狀態(tài)。其定義如下:
至此,可寫出該程控電話交換機(jī)電話機(jī)狀態(tài)轉(zhuǎn)移程序代碼(函數(shù)PhoneStateControl()),該程序代碼在主程序中100 ms被定時(shí)調(diào)用(其具體實(shí)現(xiàn)代碼略——編者注)。
5 結(jié) 論
以上兩個(gè)例子簡(jiǎn)潔、明了地實(shí)現(xiàn)了各自所要的功能。該狀態(tài)轉(zhuǎn)換的設(shè)計(jì)思想具有化繁為簡(jiǎn)的功效,同時(shí)也具有簡(jiǎn)單、易學(xué)、易用等特點(diǎn)。通過(guò)上述兩個(gè)例子的說(shuō)明及描述,相信大家對(duì)該狀態(tài)轉(zhuǎn)換思想有所了解。這種狀態(tài)轉(zhuǎn)換思想的關(guān)鍵與核心是,要能夠清楚地將問(wèn)題的狀態(tài)抽象并分解出來(lái),并且對(duì)于所有狀態(tài)的分解與描述爭(zhēng)取做到不遺漏、不冗余、層次分明。這樣,就能夠很好地理解并運(yùn)用這種思想為我們服務(wù)了。
評(píng)論