目 錄
第十一章 調試器設計... 2
11.1 調試接口... 2
11.2 界面方式調試... 3
11.3 命令行方式調試... 5
11.4 小結... 6
SuperIO 框架平台設計、開發完畢後,想把代碼編譯成程序集(DLL),二次開發都通過引用DLL實現接口、繼承類庫來實現驅動和插件的開發,SuperIO框架的代碼不會輕易去改變。這是框架設計最終要達到的效果,但是在二次開發過程中還是很不方便,主要涉及到兩方面的問題:1.開發好驅動後,如何驗證驅動的最終效果?例如:原始數據的解析、數據的處理流程和功能的實現等等,所以要在Debug模式下能夠調試驅動的源代碼,而不是調試SuperIO本身的代碼。不可能把開發好驅動反復掛載到配置文件中,反復啟動軟件來驗證驅動開發的效果,那將是耗時耗力的一件事。2.在Debug模式下,也就是在調試過程中,SuperIO框架是要有選擇性的與配置文件信息進行交互,盡管只是調試驅動模塊的源代碼,但是整個框架平台是處於調試模式,例如:在調試模式下,不加載配制文件中驅動;在調試模式下,不把設備驅動的信息寫到配制文件中等等。
基於現實應用情況,在框架平台中增加了調試器的功能。這塊代碼的實現並不復雜,但是在框架平台的體系中是必要的一部分。就像人缺少了一部分後,總顯得不那麼完美。
IDebugDevice接口定義了4個調試接口函數,主要用於對設備驅動、界面視圖、數據導出和服務組件進行源代碼調試。接口定義如下圖:
二次開發者可以繼承SuperIO.UI.MainForm窗體類來創建自己的宿主程序,可以在此基礎上進行擴展。SuperIO.UI.MainForm類本身繼承了IDebugDevice接口,並實現了每個調試接口。實現調試接口,本質上是對控制器(SuperIO.DeviceController)的操作,接口實現代碼如下:
/// <summary> /// 調試設備,傳入IRunSCLDevice接口 /// </summary> /// <param name="dev"></param> public void DebugDevice(IRunDevice dev) { this._DeviceController.AddDevice(dev); } /// <summary> /// 調試視圖窗體,該窗體必須繼承SuperIO.Show.IRTDataShow接口 /// </summary> /// <param name="rtdataform"></param> public void DebugGraphicsShow(SuperIO.Show.IGraphicsShow show) { if (show is System.Windows.Forms.Form) { System.Windows.Forms.Form from = show as System.Windows.Forms.Form; from.MdiParent = this; from.Show(); this._DeviceController.AddGraphicsShow(show); } else { MessageBox.Show("實現IGraphicsShow的同時,實例必須還得是Form類型"); } } /// <summary> /// 調試導出數據接口,該類接口必須繼承SuperIO.MiddleData.IExportData /// </summary> /// <param name="export"></param> public void DebugExportData(IExportData export) { this._DeviceController.AddExportData(new List<IExportData>(new IExportData[] { export })); } /// <summary> /// /// </summary> /// <param name="appService"></param> public void DebugAppService(IAppService appService) { if (appService.ServiceType == ServiceType.Show) { BarButtonItem bt = new BarButtonItem(this.barManager1, appService.ThisName); Font font = new Font("Tahoma", 12); bt.ItemAppearance.SetFont(font); bt.Tag = appService.ThisKey; bt.ItemClick += new ItemClickEventHandler(ServiceItem_ItemClick); barServices.AddItem(bt); } _DeviceController.AddAppService(new List<IAppService>(new IAppService[]{appService})); }
有界面方式的調試需要與配置文件進行交互,所以需要設置當前是否處於調試模式,可以通過SuperIO.Device.DebugDevice靜態類的IsDebug屬性進行標識。
建議使用這種方式對二次開發的組件進行調試。
也可以通過命令行的方式對二次開發的組件進行調試,實際上是SuperIO.Device.DebugDevice靜態類用單例的模式創建了SuperIO.UI.MainForm窗體實例,並返回了IDebugDevice接口實例。簡單的驅動和插件調試工作可以采用這種調試模式,快捷高效。代碼定義如下:
namespace SuperIO.Device { public class DebugDevice { private static object _LockObj = new object(); private static SuperIO.Device.IDebugDevice _DebugInstance = null; /// <summary> /// 獲得調試設備實例 /// </summary> /// <returns></returns> public static SuperIO.Device.IDebugDevice GetDebugInstance() { if (_DebugInstance == null) { lock (_LockObj) { if (_DebugInstance == null) { _DebugInstance = (new SuperIO.UI.MainForm()) as SuperIO.Device.IDebugDevice; } } } return _DebugInstance; } private static bool _IsDebug = false; /// <summary> /// 是否是調試模式,如果是否不調用配制文件的信息 /// </summary> public static bool IsDebug { get { return _IsDebug; } set { _IsDebug = value; } } } }
使用這種調試模式,不需要通過SuperIO.Device.DebugDevice. IsDebug屬性設置為調試模式。
任何組件的設計可能並不復雜,但是給工作帶來很大方便。調試器更多的是一個概念,並沒有太多的實際代碼,但是在二次開發過程中確實方便了很多。
下一章介紹《第12章 二次開發及應用》。