作者deo2000 (800IM)
看板C_Sharp
標題[問題] 如何有效率為某個函式庫作call log?
時間Sat Apr 11 01:27:16 2015
最近用C#在寫一個控制硬體的視窗程式,
控制該硬體的function(API) prototype 全部包在一個.cs檔裡頭,實作則是包在dll。
現在要為這個視窗程式加上call logger,作為日後追蹤debug之用,
只要呼叫到控制硬體的API全部要紀錄。
所以原本是這樣的程式:
HW_API(para0,para1);
加上call log以後就會變這樣:
RichTxtBox.AppendText(DateTime.Now.ToString() //紀錄進入API時間
HW_API(para0,para1);
RichTxtBox.ApependText(Format.String("HW_API({0},{1})",para0,para1));
這樣寫call log壞處有很多:
1. 一行程式變三行
2. 打亂原本排版
3. 很可能call log程式碼哪裡寫錯,結果要用來debug的東西自己有bug
4. 程式碼重複性高, 卻不能集中處理, 提高重用性
我一直想,有沒有可能給API.cs檔加入什麼冬冬?
作一次就可以一勞永逸,萬一有錯也比較容易發現,但想很久還是想不到,
不知道版上高手們,有沒有好的意見?
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.122.165.65
※ 文章網址: https://www.ptt.cc/bbs/C_Sharp/M.1428686839.A.DE1.html
推 Litfal: 把log output寫在API class裡面,用事件或TraceListener的04/11 02:27
TraceListen好難喔看瞴~~@@ 有什麼書在教這個class的嗎?
→ Litfal: 方式由外部註冊log追蹤,原本呼叫API的地方還是照樣呼叫。04/11 02:28
※ 編輯: deo2000 (140.122.136.18), 04/11/2015 16:24:58
→ GoalBased: 所以你可以改API嗎?04/11 21:52
如果沒有夠好的辦法,可能會考慮改API。例如在裡面插入EventHander
推 jizang: log4net 如何?04/12 02:33
暫時還不想採用第三方工具
※ 編輯: deo2000 (140.122.165.65), 04/14/2015 23:16:09
※ 編輯: deo2000 (140.122.165.65), 04/15/2015 01:03:41
推 zoeysui: 有個library叫post sharp ,可以用attribute的方式,對任 04/26 20:58
→ zoeysui: 意函數加入pre/post 處理,應該非常符合你的要求,只要可 04/26 20:58
→ zoeysui: 以接受第三方套件的話 04/26 20:58
推 tomex: 查debug.xxx()應用 能切換release即不見log; 05/15 07:10