目 錄
第十一章 調試器設計... 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章 二次開發及應用》。
新聞熱點
疑難解答