.step_filter (設定步驟篩選)
.step_filter命令會建立追蹤時略過(逐步執行)的函式清單。 這可讓您追蹤程序代碼,並只略過特定函式。 當一行有多個函數調用時,它也可用於來源模式來控制逐步執行。
.step_filter "FilterList"
.step_filter /c
.step_filter
參數
“FilterList”
指定要逐步執行之函式相關聯的符號。 FilterList 可以包含以分號分隔的任意數目文字模式。 這些模式的每一個都可能包含各種通配符和規範;如需詳細資訊,請參閱 字串通配符語法 。 函式,其符號至少符合其中一個模式,將會在追蹤期間逐步執行。 每次使用 「FilterList」 時,都會捨棄任何先前的篩選清單,並以新的清單完全取代。
/c
清除篩選清單。
Environment
項目 | 說明 |
---|---|
模式 | 使用者模式、核心模式 |
目標 | 即時、損毀傾印 |
平台 | 全部 |
備註
如果沒有任何參數, .step_filter 會顯示目前的篩選清單。
一般而言,追蹤命令(例如 t 或 windbg 偵錯 | 逐步執行] 追蹤到函式呼叫。 不過,如果與所呼叫之函式相關聯的符號符合 FilterList 所指定的模式,則會逐步執行函式,就像已使用步驟命令(例如 p) 一樣。
如果指令指標位於篩選清單中所列的程式代碼內,任何追蹤或步驟命令都會退出此函式,例如 gu 命令或 WinDbg 跳出 按鈕。 當然,此篩選會防止這類程式代碼在第一次追蹤到 ,因此只有在您已變更篩選或叫用斷點時,才會發生此情況。
例如,下列命令會導致追蹤命令略過所有 CRT 呼叫:
.step_filter "msvcrt!*"
當您 在來源模式中偵錯時,.step_filter 命令最有用,因為單一來源行可以有多個函式呼叫。 p 和 t 命令無法用來分隔這些函數調用。
例如,在下列這一行中, t 命令會逐步執行 GetTickCount 和 printf,而 p 命令會逐步執行這兩個函式呼叫:
printf( "%x\n", GetTickCount() );
.step_filter命令可讓您篩選掉其中一個呼叫,同時仍追蹤到另一個呼叫。
由於函式是以符號識別,因此單一篩選可以包含整個模組。 這可讓您篩選掉架構函式,例如,Microsoft基礎類別 (MFC) 或 Active Template Library (ATL) 呼叫。
在元件模式中偵錯時,每個呼叫都會位於不同的行上,因此您可以選擇逐步執行或逐行追蹤。 因此 ,.step_filter 在元件模式中並不十分有用。