- 相關(guān)推薦
基于Rhapsody和VxWorks的自動取款機(jī)系統(tǒng)
摘要:介紹如何運(yùn)用UML設(shè)計(jì)簡單的自動取款機(jī)系統(tǒng)模型并在操作系統(tǒng)VxWorks上實(shí)現(xiàn)它:首先,介紹如何運(yùn)用基于UML的嵌入式實(shí)時(shí)應(yīng)用軟件開發(fā)環(huán)境Rhapsody設(shè)計(jì)和實(shí)現(xiàn)自動取款機(jī)系統(tǒng)的模型,以使它能獨(dú)立于實(shí)際的硬件和使用的操作系統(tǒng);然后詳細(xì)介紹上述模型如何在實(shí)時(shí)多任務(wù)操作系統(tǒng)VxWorks上實(shí)現(xiàn)。引 言
隨著嵌入式應(yīng)用的不斷增長,嵌入式系統(tǒng)需求的復(fù)雜性、不確定性不斷提高,系統(tǒng)規(guī)模也逐步擴(kuò)大;而產(chǎn)品的研發(fā)周期又在很快地縮短,給嵌入式應(yīng)用軟件的開發(fā)帶來了新的挑戰(zhàn)。同時(shí),嵌入式軟件的開發(fā)者必須面對由于芯片性能的增長、嵌入式操作系統(tǒng)平臺等技術(shù)方面不斷變化所帶來的各種壓力。嵌入式軟件開發(fā)環(huán)境的發(fā)展,使一直“深埋”于系統(tǒng)的嵌入式應(yīng)用軟件變得開放而易于開發(fā),從而促進(jìn)了嵌入式技術(shù)的廣泛應(yīng)用。
1 基于UML的嵌入式軟件開發(fā)環(huán)境結(jié)構(gòu)
??圖1所示為一種支持基于UML(Unified Modeling Language,統(tǒng)一建模語言)的迭代式開發(fā)方法的開發(fā)環(huán)境的結(jié)構(gòu),虛框部分為基于UML的軟件開發(fā)環(huán)境。
??系統(tǒng)分析和設(shè)計(jì)用UML來描述,對系統(tǒng)建模;實(shí)現(xiàn)過程利用代碼自動生成技術(shù)來實(shí)現(xiàn);測試過程將依賴于生成的代碼,通過在代碼中拆裝一些用于支持模型調(diào)試的調(diào)試信息來實(shí)現(xiàn);而代碼的編譯、鏈接則采用目標(biāo)系統(tǒng)的操作系統(tǒng)開發(fā)環(huán)境來完成,代碼的運(yùn)行與源程序級的調(diào)試仍然采用一般的嵌入式軟件調(diào)試環(huán)境。
??Rhapsody是一個(gè)基于UML的面向嵌入式實(shí)時(shí)應(yīng)用開發(fā)的集成、可視化環(huán)境。軟件開發(fā)者可以在這個(gè)環(huán)境里進(jìn)行分析、設(shè)計(jì)、實(shí)現(xiàn)及驗(yàn)證。Rhapsody支持基于模型的調(diào)試;提供專門為實(shí)時(shí)嵌入式應(yīng)用設(shè)計(jì)的可執(zhí)行的框架,可以產(chǎn)生基于VxWorks、POS、OSE等多種操作系統(tǒng)的C語言、C 語言、Java語言的源程序。本文所給出的自動取款機(jī)系統(tǒng)的模型正是基于Rhapsody設(shè)計(jì)的。
2 自動取款機(jī)系統(tǒng)模型的設(shè)計(jì)
2.1 需求分析
??我們設(shè)計(jì)的自動取款機(jī)系統(tǒng)要滿足如下要求:
??在自動取款機(jī)系統(tǒng)中,當(dāng)顧客在自動取款機(jī)操作面板上插入信用卡并輸入密碼和現(xiàn)金支取數(shù)額(每次最多只能取一千元)后,由自動取款機(jī)讀取卡上的內(nèi)容,并把相應(yīng)信息傳送到銀行。銀行把自動取款機(jī)送來的信息與銀行帳號上的信息進(jìn)行比較,如果兩者一致,則銀行傳送確認(rèn)信息到自動取款機(jī),由自動取款機(jī)輸出現(xiàn)金,然后顧客取出卡和現(xiàn)金;如果兩者不一致,則要求顧客再次輸入密碼和現(xiàn)金支取數(shù)額,然后重復(fù)上述操作;若密碼輸入三次不正確,自動取款機(jī)就會吞掉信用卡,顧客就不能取出信用卡和現(xiàn)金。
??該自動取款機(jī)系統(tǒng)包括1個(gè)鍵盤(10個(gè)數(shù)字鍵、ENTER鍵和CANCEL鍵)、1個(gè)LCD液晶顯示屏、1個(gè)插卡孔和1個(gè)現(xiàn)金出口;通過雙絞線與銀行中的電腦進(jìn)行串行通信。該自動取款機(jī)系統(tǒng)不包括銀行中的電腦,只是通過軟件與銀行中的上位機(jī)進(jìn)行串行通信。
2.2 可視化建模
??建模是面向?qū)ο蠓治龊驮O(shè)計(jì)的核心,也是分析和設(shè)計(jì)過程中最基本和最關(guān)鍵的活動之一。UML不僅適用于以面向?qū)ο蠹夹g(shù)描述的任何類型的系統(tǒng),而且適用于系統(tǒng)開發(fā)的不同階段。根據(jù)開發(fā)過程中不同階段的具體要求,利用UML不同類型的圖來描述系統(tǒng)的各種靜態(tài)結(jié)構(gòu)模型和動態(tài)行為模型。下面介紹如何利用基于UML的面向嵌入式實(shí)時(shí)應(yīng)用開發(fā)的集成可視化環(huán)境Rhapsody創(chuàng)建自動取款機(jī)系統(tǒng)的模型。
圖3 取出現(xiàn)金的黑匣子場景
第一步:根據(jù)要求建立用例圖。
??圖2所示為用例圖。圖中給出了自動取款機(jī)系統(tǒng)的主要用途,并表明由誰使用自動取款機(jī)系統(tǒng)。有一個(gè)主要成員——顧客。一個(gè)用例圖應(yīng)該具有這樣的系統(tǒng)功能:對操作者而言,它返回可觀察的結(jié)果但并不顯示系統(tǒng)的內(nèi)在結(jié)構(gòu)。
??自動取款機(jī)系統(tǒng)的主要用途是“取出現(xiàn)金”用例。顧客參與其中的兩個(gè)實(shí)例是“輸入密碼”和“取出現(xiàn)金”。這兩個(gè)實(shí)例都包含了另一個(gè)用例“讀取卡上內(nèi)容并驗(yàn)證”。對每一個(gè)用例而言,我們都可以增加文本描述。假如需要的話,這些用例能夠被細(xì)化成另一張更多用例的圖。這些用例并沒有顯示任何內(nèi)在的結(jié)構(gòu),僅是一個(gè)功能性的視圖。
第二步:設(shè)計(jì)黑匣子場景。
??建立了一個(gè)用例圖后,下一步便是細(xì)化用例,即設(shè)計(jì)一些黑匣子場景。這些黑匣子場景的主要作用是表明模型和對象之間的相互關(guān)系。把整個(gè)系統(tǒng)看作一個(gè)整體,對 “取出現(xiàn)金” 用例,我們細(xì)化為圖3所示的場景。(由于每次最多只能取一千元,所以最多只需要按鍵4次。)
??圖3所示的場景能被MSD(消息序列表)捕獲,用來描述在顧客和自動取款機(jī)系統(tǒng)之間的通信行為。當(dāng)創(chuàng)建這樣的圖表時(shí),關(guān)于系統(tǒng)的更多細(xì)節(jié)被隱藏了;同時(shí),這些場景幫助我們更好地理解使用者如何使用報(bào)警系統(tǒng)以及需要做哪些事情。總而言之,每一用例都有很多的場景需要捕獲,每一個(gè)場景都是用例的一個(gè)有效的實(shí)例。
第三步:設(shè)計(jì)子系統(tǒng)圖。
??下一步是如何把模型分割成子系統(tǒng)。在UML中,一個(gè)子系統(tǒng)作為一個(gè)封裝顯示,即主要是一個(gè)類的集合。圖4的子系統(tǒng)圖表明自動取款機(jī)系統(tǒng)已經(jīng)被分解成兩個(gè)基本的部分:自動柜員機(jī)封裝(AtmerPkg)和硬件封裝(HardharePkg)。同時(shí)也表明:自動柜員機(jī)封裝是完全獨(dú)立于實(shí)際的硬件和硬件封裝的,并且實(shí)現(xiàn)了Ihardware接
【基于Rhapsody和VxWorks的自動取款機(jī)系統(tǒng)】相關(guān)文章:
基于VxWorks的多DSP系統(tǒng)的多任務(wù)程序設(shè)計(jì)03-18
基于VxWorks的bootrom代碼改進(jìn)03-18
使用Rhapsody軟件框架和UML的實(shí)時(shí)系統(tǒng)開發(fā)03-07
基于嵌入式操作系統(tǒng)VxWorks的SCSI硬盤高速記錄系統(tǒng)03-18
基于Vxworks實(shí)時(shí)操作系統(tǒng)的串口通信程序設(shè)計(jì)與實(shí)現(xiàn)03-18
基于ARM7核處理器VxWorks系統(tǒng)BSP設(shè)計(jì)03-19
基于Verilog HDL設(shè)計(jì)的自動數(shù)據(jù)采集系統(tǒng)03-21