選項對話方塊、偵錯、一般
若要存取 [一般] 頁,請開啟 [工具] 功能表,並選擇 [選項]。 在 [選項] 對話方塊中,展開 [偵錯] 節點,然後選擇 [一般]。 這個頁面可以讓您設定下列一般偵錯選項:
刪除所有中斷點時先詢問
完成 [刪除所有中斷點] 命令之前需要確認。如果其中一個處理序中斷,就中斷所有處理序
發生中斷時,同時中斷偵錯工具附加至的所有處理序。例外狀況為跨 AppDomain 或 Managed/原生界限時中斷
在 Managed 或混合模式偵錯中,當符合下列條件,Common Language Runtime 就可以攔截跨應用程式定義域界限或 Managed/原生界限的例外狀況:1) 當機器碼使用 COM Interop 呼叫 Managed 程式碼,且 Managed 程式碼擲回例外狀況時。 請參閱 COM Interop 簡介 (Visual Basic)。
2) 當在應用程式定義域 A 中執行的 Managed 程式碼呼叫應用程式定義域 B 中的 Managed 程式碼,且應用程式定義域 B 中的程式碼擲回例外狀況時。 請參閱 使用應用程式定義域設計程式。
3) 當程式碼使用反映 (Reflection) 呼叫函式,且函式擲回例外狀況時。 請參閱 .NET Framework 中的反映。
在 2) 和 3) 中的例外狀況有時會被 mscorlib 中的 Managed 程式碼攔截,而非被 Common Language Runtime 攔截。 這個選項不會影響被 mscorlib 攔截之例外狀況的中斷。
啟用位址層級偵錯
在位址層級啟用偵錯的進階功能 ([反組譯碼] 視窗、[暫存器] 視窗和位址中斷點)。找不到原始碼時則顯示反組譯碼
當您嘗試偵錯無法使用原始碼的程式碼時,將會自動顯示 [反組譯碼] 視窗。啟用中斷點篩選條件
可讓您設定中斷點的篩選條件,讓中斷點只會影響特定處理序、執行緒或電腦。啟用例外狀況助理
僅適用於 Managed 程式碼。 選取這個選項時,Managed 例外狀況會開啟新的 [例外狀況助理] 對話方塊,而非舊的 [例外狀況] 對話方塊。 [例外狀況助理] 的內容更加詳細,而對於例外狀況也能夠提供更有效的幫助。 請參閱 例外狀況助理。發生未處理的例外狀況時回溯呼叫堆疊
導致 [呼叫堆疊] 視窗將呼叫堆疊復原到無法處理的例外狀況發生之前。啟用 Just My Code
啟用這個功能時,會顯示偵錯工具並僅逐步執行使用者程式碼 ("My Code"),並忽略系統程式碼和其他已最佳化或沒有偵錯符號的程式碼。在變數視窗中顯示非使用者物件的所有成員 (僅限 Visual Basic)
開啟非使用者程式碼 (非 "My Code") 中物件的非公用成員顯示畫面。如果啟動時沒有使用者程式碼則警告
在啟用 Just My Code 的狀態下開始偵錯時,如果沒有使用者程式碼 ("My Code"),這個選項會警告您。啟用 .NET Framework 原始碼逐步偵錯
允許偵錯工具逐步執行 .NET Framework 原始檔。 啟用此選項會自動停用 Just My Code。.NET Framework 符號會下載到快取位置。 您可以在 [選項] 對話方塊,[偵錯] 分類,[符號] 頁面中變更快取位置。不進入屬性和運算子 (僅限 Managed)
讓偵錯工具無法逐步執行 Managed 程式碼中的屬性和運算子。啟用屬性評估及其他隱含函式呼叫
開啟變數視窗和 [快速監看式] 對話方塊中的屬性自動評估與隱含函式呼叫。在變數視窗中呼叫物件的字串轉換函式 (僅限 C# 和 JavaScript)
在評估變數視窗中的物件時,執行隱含的字串轉換呼叫。 因此,該結果會顯示為字串,而非類型名稱。 只適用於偵錯 C# 程式碼時。 DebuggerDisplay 屬性可能會覆寫這個設定 (請參閱使用 DebuggerDisplay 屬性)。啟用來源伺服器支援
告知 Visual Studio Debugger 從實作 SrcSrv (srcsrv.dll) 通訊協定的來源伺服器取得來源檔。 Team Foundation Server 和 Debugging Tools for Windows 是實作通訊協定的兩個來源伺服器。 如需 SrcSrv 設定的詳細資訊,請參閱 Debugging Tools for Windows 文件。 此外,請參閱在 Visual Studio Debugger 中指定符號 (.pdb) 和原始程式檔。安全性提示 因為讀取 .pdb 檔案可以執行檔案中的任意程式碼,請確定您信任伺服器。
將來源伺服器診斷訊息列印到 [輸出] 視窗
啟用來源伺服器支援時,這個設定會開啟診斷顯示畫面。允許部分信任組件的來源伺服器 (僅限 Managed)
當來源伺服器支援啟用時,這個設定會覆寫不擷取部分信任組件之來源的預設行為。反白顯示中斷點的整個原始程式行及目前的陳述式
當偵錯工具反白顯示中斷點或目前的陳述式時,它會反白顯示整行。原始程式檔必須完全符合原始版本
告知偵錯工具驗證原始程式檔是否符合用來建置正在偵錯之可執行檔的原始程式碼版本。 如果版本不符,將提示您尋找相符的原始程式檔。 如果找不到相符的原始程式檔,偵錯期間將不會顯示原始程式碼。將所有 [輸出] 視窗文字重新導向到 [即時運算] 視窗
將通常會出現在 [輸出] 視窗的所有偵錯工具訊息,改成傳送到 [即時運算] 視窗。在 [變數] 視窗中顯示物件的原始結構
關閉所有物件結構檢視自訂。 如需檢視自訂的詳細資訊,請參閱顯示自訂資料類型。模組載入時隱藏 JIT 最佳化 (僅限 Managed)
在附加偵錯工具時若已載入模組且已編譯 JIT,便停用 Managed 程式碼的 JIT 最佳化。 停用最佳化可更容易偵錯一些問題,但消耗較多效能。 如果正在使用 Just My Code,隱藏 JIT 最佳化會使非使用者程式碼顯示為使用者程式碼 ("My Code")。如果啟動時沒有符號,就提出警告 (僅限機器碼)
如果選取這個選項,即可在您嘗試偵錯一個偵錯工具沒有符號資訊的程式時,顯示警告對話方塊。 請參閱 No Symbolic Information Dialog Box。如果啟動時指令碼偵錯處於停用狀態則警告
選取這個選項即可在啟動偵錯工具卻停用指令碼偵錯時,顯示警告對話方塊。載入 DLL 匯出
選取此選項將會載入 DLL 匯出表。 如果您使用 Windows 訊息、Windows 程序 (WindowProc)、COM 物件、封送處理 (Marshaling) 或是沒有其符號的任何 DLL,則 DLL 匯出表的符號資訊就會很有用。 讀取 DLL 匯出資訊會產生一些額外負荷, 因此,這項功能預設為關閉。若您想知道 DLL 匯出表中可使用的符號,請使用 dumpbin /exports。 這些符號適用於任何 32 位元系統 DLL。 讀取 dumpbin /exports 輸出時,您可以看到確實的函式名稱,包含非英數字元。 這對設定函式的中斷點來說很有幫助。 DLL 匯出表中的函式名稱在偵錯工具中的其他位置可能會顯示為已被截斷。 這些呼叫都按呼叫順序列出,目前的函式 (巢狀最深處) 列在頂端。 如需詳細資訊,請參閱 dumpbin /exports。
由下而上顯示平行堆疊圖表
控制堆疊在 [平行堆疊] 視窗中顯示的方向。如果寫入的資料未變更值,請忽略 GPU 記憶體存取例外狀況
如果資料沒有變更,請忽略偵錯期間偵測到的競爭條件。 如需詳細資訊,請參閱偵錯 GPU 程式碼。使用 Managed 相容性模式
將預設偵錯引擎取代為舊版偵錯引擎,以啟用這些案例:您要使用 C#、VB 或 F# 以外的 .NET Framework 語言 (包括 C++/CLI),以提供其自己的運算式評估工具。
您要在混合模式偵錯時啟用 C++ 專案的 [編輯後繼續] (EnC)。
請注意,選擇 Managed 相容性模式會停用只在預設偵錯引擎中實作的一些功能。