Chapter說到糾纏不清的工程管理器的問題。
很多模塊都需要在工程打開之時,獲取一定的信息,比如工程是新建的還是打開的,臨時目錄在哪里,工程目錄又在哪里。
工程管理模塊就像個奶媽,把一系列的信息從XML文件或者從用戶剛剛輸入的信息都進來,然后再一個個的去NotifyProjectOpen。工程關閉之時在挨個通知他們要關燈了,NotifyProjectClose。怪不得耦合度高啊,全是被動式初始化,能不高嗎?
修改方案:
干脆,奶媽下崗吧,最好自己的事,別人的事少管。有了狀況通知專門的部門專門的人去管。ProjectMgr負責解析工程文件,并把自己的指針注冊到InterfaceMgr,有MagicString的都可獲取。需要一個通信協議,讓各位斷奶的模塊來獲取自己需要的東西。有兩種打算,一個就是通過一個結構體,把工程的消息全部裝到里面,誰要誰就調ProjectMgr的接口要,拿回去自己挑,需要什么就讀出什么來,自個初始化自個。各個數據結構對象弄成static的,工程打開或參數改變的時候ProjectMgr更新它,然后ProjectMgr通知相關部門讓娃娃們都來取最新的工程信息。第二個打算就是,ProjectManager只提供工程文件的路徑,誰要給誰,誰需要誰自己解析去,這樣把耦合徹底解開了。
娃娃們還需要長點本事才能做到主動初始化,怎么辦呢?找個好師傅吧。CPlugIn,中間的方法NotifyProjectOpen, NotifyProjectClose都做了是實現,全部直接return。誰需要初始化自己,找InterfaceMgr要PrjMgr指針,找PrjMgr要信息,自個初始化自個去。
誰是相關部門呢?
InterfaceMgr人人向他注冊指針,可以兼職。娃娃注冊自己時,同時把自己的父類指針CPlugIn也注冊進去。PrjMgr一來通知,InterfaceMgr根據指針列表全部觸發。這不是很多態,很命令模式,很OO嗎?
----------------------------------------------------------
剩下的部門是最復雜的,所有的邏輯都在界面里,實現類只有一個Show。有的部分一個連貫的動作,分解到兩個類中。數據庫的接口,層次不清,也很頭痛啊。
posted on 2008-08-14 17:47
創建更好的解決方案 閱讀(1151)
評論(0) 編輯 收藏 引用 所屬分類:
C++專欄 、
軟件設計