Visual Studio調試之斷點

 我曾經問過很多人,你一般是怎麼調試你的程序的?

  F9, F5, F11, F……

  有很多書和文章都是介紹怎 麼使用Visual Studio編寫WinForm啦,、ASP.NET之類的程序;知道如何編寫固然重要,但是我覺得程序員可能只會花費30%的時間在編寫代碼上,剩下的 大部分時間都是在調試程序。在網上看到很多人介紹Windbg的用法,但是沒有看到幾篇講解使用Visual Studio調試的文章。Windbg固然強大,但是問題是它的學習曲線太陡了,而且很多調試並不需要使用Windbg來調試(當然啦,並不是指我不會 Windbg調試啦—這是以後的調試系列文章將要講的),爲什麼不使用我們最熟悉的Visual Studio來進行調試呢?

  調試嘛,無非就是要看看程序在運行時候,內部的狀態,例如一些變量的值是多少,看一看程序調用的路徑啦之類的。當然最直接的方式就是直接中斷程序的執行,用調試器去檢查一下程序的情況嘛。於是F9, F5, F10, F11……

   那麼我們就來說說什麼是斷點,斷點是什麼?不是F9 ,也不是那個小紅球,在Intel系列的CPU(包括AMD生產的CPU)裏面,它其實是一個特殊的指令—INT 3。CPU在執行程序的指令集的時候,只要碰到這個指令,就會中斷程序的執行(當然啦,CPU會通知操作系統,然後……然後……然後……,斷點的實現機制 我會在以後的文章裏面講解,現在我們就只要知道那個INT 3指令會中斷程序的執行好嗎?)。

  當然啦,我們需要用事實來證明我上面的話,因此把下面的程序編譯並且執行一下,點“Yes”,點“Break”,對對對,程序中斷了,我相信你可以看見的:

#include <stdio.h>
 
void main()
{
       printf("Before breakpoint"n");
       __asm
       {
              int 3
       }
       printf("Before breakpoint"n");
}

  編譯方法:

  1.       在開始菜單中打開Visual Studio 2008[2005] Command Prompt(Visual Studio 2008[2005]命令行)。

  2.       進入保存上面 C源代碼(int3.c)的文件夾的路徑。

  3.       執行編譯命令(因爲我的機器是Windows 7 RC + Visual Studio 2008 + x64 CPU,直接編譯有一點問題,如果你的機器不是我上面的配置,可以嘗試執行

  cl /Zi int3.c)

  cl /Zi /c int3.c

  4.       執行鏈接命令(如果你直接執行了命令cl /Zi int3.c的話就可以跳過這一步)。

  link /libpath:"C:"Program Files"Microsoft SDKs"Windows"v6.0A"Lib" int3.obj

  5.       運行輸出的int3.exe。

  這時你應該會看到Visual Studio彈出來,然後在源代碼行的int 3上面中斷,說明我們已經成功地讓CPU中斷int3.exe程序 的執行了。

  提示

   :如果你執行int3.exe的時候,沒有發現Visual Studio窗口彈出來的話,那麼請點擊Visual Studio菜單項裏面的“Tools(工具)”—“Options(選項)”,接着在“Options(選項)”窗口中選擇 “Debugging(調試)”—“Just-In-Time(即時調試)”,然後勾選“Native(原生程序)”選項。如下圖所示:

Visual Studio調試之斷點基礎篇


  “綜上所述,斷點是int 3這個指令觸發的!(小時候的數學證明題)”。

 

 

  由int 3這個指令(當然是在intel系列的CPU上面)引申出來有哪些函數呢:

  語言/工具

  名稱

  描述

  C++

  DebugBreak

  在C++代碼中硬編碼一個斷點。

 

  C#

  Debugger.Break

  在.NET代碼中硬編碼一個斷點

  Visual Studio

  斷點

  設置一個斷點

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章