Debugging, Profiling, Code improvement tools
  • Introduction
  • Chapter1: 追蹤問題
    • 1.1.找出錯誤來源
  • Chapter2: 解決問題
    • 2.1.Check list
      • 2.1.1.確認前後條件
  • Chapter3: 錯誤訊息
    • 3.1.python
      • 'charmap' codec can't decode byte 0x8f in position 17: character maps to <undefined>
  • Chapter4:版本管理工具
    • 4.1.Git
      • 4.1.1.Working tree, Index/Cache, Repository and Object
      • 4.1.2.commit
      • 4.1.3.cherry-pick
      • 4.1.4.rebase
    • 4.2.TortoiseGit
      • 4.2.1.bisect
      • 4.4.2.reflog & reset
      • 4.2.3.blame
  • Chapter5: 除錯工具
    • 5.1.Visual studio
      • 5.1.1.輸出debug訊息
      • 5.1.2.中斷點
      • 5.1.3.載入符號, 檢視堆疊
      • 5.1.4.追蹤點
      • 5.1.5.單步執行程式
      • 5.1.6.日誌
      • 5.1.7.靜態程式分析
    • 5.2. WinDbg
      • 5.2.1.安裝WinDbg
      • 5.2.2.設定project及symbol path
      • 5.2.3.分析.dmp file
    • 5.3.API
      • 5.3.1.核心傾印
  • Chapter6: 效能分析工具
    • 6.1.Introduction
    • 6.2.Windows
      • 6.2.1.效能分析指標
      • 6.2.2.Windows Performance Monitor
      • 6.2.3.Process monitor
      • 6.2.4.Windows Performance Toolkit
    • 6.3.C++ project
      • 6.3.1.SMART BEAR AQ Time
    • 6.4.Python project
      • 6.4.1.cProfile, snakeviz
  • Chapter7: 程式碼優化工具
    • 7.1.Python
      • 7.1.1.vulture
Powered by GitBook
On this page
  • 1.目的
  • 2.日誌記錄函式庫

Was this helpful?

  1. Chapter5: 除錯工具
  2. 5.1.Visual studio

5.1.6.日誌

Previous5.1.5.單步執行程式Next5.1.7.靜態程式分析

Last updated 5 years ago

Was this helpful?

1.目的

  • 日誌記錄陳述可以追蹤與理解程式的執行

  • 日誌陳述的輸出比較方便過濾與查詢

2.日誌記錄函式庫

  • 1.Windows API: ReportEvent

    • 1.在程式中呼叫API以在Windows Event log中留下紀錄

            #include "stdafx.h"
            #include <windows.h>
      
            int _tmain(int argc, _TCHAR* argv[])
            {
                LPTSTR lpszStrings[] = {"Called main() in file", __FILE__};
                HANDLE hEventSource = RegisterEventSource(NULL, "myService");
                if (hEventSource == NULL){
                       return 1;
                }
                ReportEvent(hEventSource,
                   EVENTLOG_INFORMATION_TYPE,
                   0,
                   0,
                   NULL,
                   2,
                   0,
                   (LPCSTR*)lpszStrings,
                   NULL);
      
                DeregisterEventSource(hEventSource);
                return 0;
            }
    • 2.檢視Windows Event log

      • 在開始功能表下輸入以下指令即可打開Windows Event log

              eventvwr.msc