一、銀行業務排程系統需求
模拟實作銀行業務排程系統邏輯,具體需求如下:
銀行内有6個業務視窗,1 - 4号視窗為普通視窗,5号視窗為快速視窗,6号視窗為VIP視窗。
有三種對應類型的客戶:VIP客戶,普通客戶,快速客戶(辦理如交水電費、電話費之類業務的客戶)。
異步随機生成各種類型的客戶,生成各類型使用者的機率比例為:
VIP客戶 :普通客戶 :快速客戶 = 1 :6 :3。
客戶辦理業務所需時間有最大值和最小值,在該範圍内随機設定每個VIP客戶以及普通客戶辦理業務所需的時間,快速客戶辦理業務所需時間為最小值(提示:辦理業務的過程可通過線程Sleep的方式模拟)。
各類型客戶在其對應視窗按順序依次辦理業務。
當VIP(6号)視窗和快速業務(5号)視窗沒有客戶等待辦理業務的時候,這兩個視窗可以處理普通客戶的業務,而一旦有對應的客戶等待辦理業務的時候,則優先處理對應客戶的業務。
随機生成客戶時間間隔以及業務辦理時間最大值和最小值自定,可以設定。
不要求實作GUI,隻考慮系統邏輯實作,可通過Log方式展現程式運作結果。
二、面向對象的分析與設計:
1、有三種對應類型的客戶:VIP客戶,普通客戶,快速客戶 ,異步随機生成各種類型的客戶,各類型客戶在其對應視窗按順序依次辦理業務 。。
> 首先,去銀行辦理業務,先要獲得一個号碼,這就類似于挂号,然後銀行的從業人員根據電腦産生的号碼來為客戶服務。這就需要一個号碼管理器對象,讓這個對象不斷的産生号碼,就等于随機生成客戶。
> 由于有三類客戶,每類客戶的号碼編排都是完全獨立的,是以,本系統一共要産生三個号碼管理器對象,各自管理一類使用者的排隊号碼。這三個号碼管理器對象統一由一個号碼機器進行管理,這個号碼機器在整個系統中始終隻能有一個,是以,它要被設計成單例。
2、各類型客戶在其對應視窗按順序依次辦理業務 ,準确地說,應該是視窗依次叫号。
> 各個視窗怎麼知道該叫哪一個号了呢?它一定是問的相應的号碼管理器,即服務視窗每次找号碼管理器擷取目前要被服務的号碼。
> 用類圖來分析了解:

一個号碼産生器NumberMachine 管理三類号碼普通使用者、VIP使用者、快速使用者。而NumberManager 類則用于産生的号碼、和擷取号碼。而ServiceWindow 在NumberManager 擷取号碼。
三、編寫:
NumberManager類
> 定義一個用于存儲上一個客戶号碼的成員變量和用于存儲所有等待服務的客戶号碼的隊列集合。
> 定義一個産生新号碼的方法和擷取馬上要為之服務的号碼的方法,這兩個方法被不同的線程操作了相同的資料,是以,要進行同步。
NumberMachine類
> 定義三個成員變量分别指向三個NumberManager對象,分别表示普通、快速和VIP客戶的号碼管理器,定義三個對應的方法來傳回這三個NumberManager對象。
> 将NumberMachine類設計成單例。
CustomerType枚舉類
> 系統中有三種類型的客戶,是以用定義一個枚舉類,其中定義三個成員分别表示三種類型的客戶。
> 重寫toString方法,傳回類型的中文名稱。這是在後面編碼時重構出來的,剛開始不用考慮。
ServiceWindow類
> 定義一個start方法,内部啟動一個線程,根據服務視窗的類别分别循環調用三個不同的方法。
> 定義三個方法分别對三種客戶進行服務,為了觀察運作效果,應詳細列印出其中的細節資訊。
MainClass類
> 用for循環建立出4個普通視窗,再建立出1個快速視窗和一個VIP視窗。
> 接着再建立三個定時器,分别定時去建立新的普通客戶号碼、新的快速客戶号碼、新的VIP客戶号碼。
Constants類
> 定義三個常量:MAX_SERVICE_TIME、MIN_SERVICE_TIME、COMMON_CUSTOMER_INTERVAL_TIME
總結:在寫做這種模拟型項目隻有對業務流程足夠了解才能完成編寫,也隻有在對業務流程足夠了解,才能在面向對象設計和分析的時候更準确的定義出項目中的各種對象,以及對象擁有的方法、對象與對象之間的聯系。加油!
系轉載
若轉載請注明出處!若有疑問,請回複交流!