DEBUG命令詳解教程第1/2頁
來源:互聯網
上載者:User
DEBUG是DOS中的一個外部命令,從DOS 1.0起就帶有此命令,因此可見此命令的重要性了。雖然此命令的功能非常強大,可以解決許多問題,可是對許多人來說,尤其是初學者來說,卻非常不易掌握。因此,現將DEBUG的命令詳細介紹一番,以讓大家知道它的使用。
Debug:A(彙編)
直接將 8086/8087/8088 記憶碼合并到記憶體。
該命令從組合語言語句建立可執行檔機器碼。所有數值都是十六進位格式,必須按一到四個字元輸入這些數值。在引用的作業碼(作業碼)前指定首碼記憶碼。
a [address]
參數
address
指定鍵入組合語言指令的位置。對 address 使用十六進位值,並鍵入不以“h”字元結尾的每個值。如果不指定地址,a 將在它上次停止處開始彙編。
有關將資料輸入到指定位元組中的資訊,請單擊“相關主題”列表中的 Debug E(鍵入)。
有關反組譯碼位元組的資訊,請單擊“相關主題”列表中的 Debug U(反組譯碼)。
說明
使用記憶碼
段的替代記憶碼為 cs:、ds:、es: 和 ss:。遠程返回的記憶碼是 retf。字串處理的記憶碼必須明確聲明字串大小。例如,使用 movsw 可以移動 16 位的字串,使用 movsb 可以移動 8 位位元組串。
彙編跳轉和調用
組譯工具根據位元組替換自動將短、近和遠的跳轉及調用彙編到目標地址。通過使用 near 或 far 首碼可以替代這樣的跳轉或調用,如下例所示:
-a0100:0500
0100:0500 jmp 502 ; a 2-byte short jump
0100:0502 jmp near 505 ; a 3-byte near jump
0100:0505 jmp far 50a ; a 5-byte far jump
可以將 near 首碼縮寫為 ne。
區分字和位元組記憶體位置
當某個運算元可以引用某個字記憶體位置或者位元組記憶體位置時,必須用首碼 word ptr 或者首碼 byte ptr 指定資料類型。可接受的縮寫分別是 wo 和 by。以下範例顯示兩種格式:
dec wo [si]
neg byte ptr [128]
指定運算元
Debug 使用包括在中括弧 ([ ]) 的運算元引用記憶體位址的習慣用法。這是因為另一方面 Debug 不能區分立即運算元和記憶體位址的運算元。以下範例顯示兩種格式:
mov ax,21 ; load AX with 21h
mov ax,[21] ; load AX with the
; contents of
; memory location 21h
使用偽指令
使用 a 命令提供兩個常用的偽指令:db 作業碼,將位元組值直接彙編到記憶體,dw 作業碼,將字值直接彙編到記憶體。以下是兩個偽指令的範例:
db 1,2,3,4,"THIS IS AN EXAMPLE"
db 'THIS IS A QUOTATION MARK:"'
db "THIS IS A QUOTATION MARK:'"
dw 1000,2000,3000,"BACH"
範例
a 命令支援所有形式的間接註冊命令,如下例所示:
add bx,34[bp+2].[si-1]
pop [bp+di]
push [si] )
還支援所有作業碼同義字,如下例所示:
loopz 100
loope 100
ja 200
jnbe 200
對於 8087 作業碼,必須指定 wait 或 fwait 首碼,如下例所示:
fwait fadd st,st(3) ; this line assembles
; an fwait prefix
Debug:C(比較)
比較記憶體的兩個部分。
c range address
參數
range
指定要比較的記憶體第一個地區的起始和結束位址,或起始地址和長度。有關有效 range 值的資訊,請單擊“相關主題”列表中的“Debug 說明”。
address
指定要比較的第二個記憶體地區的起始地址。有關有效 address 值的資訊,請單擊“相關主題”列表中的“Debug 說明”。
說明
如果 range 和 address 記憶體地區相同,Debug 將不顯示任何內容而直接返回到 Debug 提示符。如果有差異,Debug 將按如下格式顯示:
address1 byte1 byte2 addess2
範例
以下命令具有相同效果:
c100,10f 300
c100l10 300
每個命令都對 100h 到 10Fh 的記憶體資料區塊與 300h 到 30Fh 的記憶體資料區塊進行比較。
Debug 響應前面的命令並顯示如下資訊(假定 DS = 197F):
197F:0100 4D E4 197F:0300
197F:0101 67 99 197F:0301
197F:0102 A3 27 197F:0302
197F:0103 35 F3 197F:0303
197F:0104 97 BD 197F:0304
197F:0105 04 35 197F:0305
197F:0107 76 71 197F:0307
197F:0108 E6 11 197F:0308
197F:0109 19 2C 197F:0309
197F:010A 80 0A 197F:030A
197F:010B 36 7F 197F:030B
197F:010C BE 22 197F:030C
197F:010D 83 93 197F:030D
197F:010E 49 77 197F:030E
197F:010F 4F 8A 197F:030F
注意列表中缺少地址 197F:0106 和 197F:0306。這表明那些地址中的值是相同的。
Debug:D(轉儲)
顯示一定範圍記憶體位址的內容。
d [range]
參數
range
指定要顯示其內容的記憶體地區的起始和結束位址,或起始地址和長度。有關有效 range 值的資訊,請單擊“相關主題”列表中的“Debug 說明”。如果不指定 range,Debug 程式將從以前 d 命令中所指定的位址範圍的末尾開始顯示 128 個位元組的內容。
有關顯示寄存器內容的資訊,請單擊“相關主題”列表中的 Debug R(寄存器)。
說明
當使用 d 命令時,Debug 以兩個部分顯示記憶體內容:十六進位部分(每個位元組的值都用十六進位格式表示)和 ASCII 碼部分(每個位元組的值都用 ASCII 碼字元表示)。每個非列印字元在顯示的 ASCII 部分由句號 (.) 表示。每個顯示行顯示 16 位元組的內容,第 8 位元組和第 9 位元組之間有一個連字號。每個顯示行從 16 位元組的邊界上開始。
範例
假定鍵入以下命令:
dcs:100 10f
Debug 按以下格式顯示範圍中的內容:
04BA:0100 54 4F 4D 00 53 41 57 59-45 52 00 00 00 00 00 00 TOM.SAWYER......
如果在沒有參數的情況下鍵入 d 命令,Debug 按以前範例中所描述的內容來編排顯示格式。顯示的每行以比前一行的地址大 16 個位元組(如果是顯示 40 列的螢幕,則為 8 個位元組)的地址開頭。
對於後面鍵入的每個不帶參數的 d 命令,Debug 將緊接在最後顯示的命令後立即顯示位元組內容。
如果鍵入以下命令,Debug 將從 CS:100 開始顯示 20h 個位元組的內容:
dcs:100 l 20
如果鍵入以下命令,Debug 將顯示範圍從 CS 段的 100h 到 115h 中所有位元組的內容:
dcs:100 115
Debug:E(鍵入)
將資料輸入到記憶體中指定的地址。
可以按十六進位或 ASCII 格式鍵入資料。以前儲存在指定位置的任何資料全部丟失。
e address [list]
參數
address
指定輸入資料的第一個記憶體位置。
list
指定要輸入到記憶體的連續位元組中的資料。
有關整合記憶碼的資訊,請單擊“相關主題”列表中的 Debug A(彙編)。
有關顯示記憶體部分內容的資訊,請單擊“相關主題”列表中的 Debug D (轉儲)。
說明
使用 address 參數
如果在沒有指定可選的 list 參數的值情況下指定 address 的值,Debug 將顯示地址和內容,在下一行重複地址,並等待您的輸入。此時,您可以執行下列操作之一:
替換位元組值。為此,請在當前值後鍵入新值。如果您鍵入的值不是有效十六進位值,或該值包含兩個以上的數字,則 Debug 不會回顯無效或額外的字元。
進入下一個位元組。為此,請按 SPACEBAR(空格鍵)。要更改該位元組中的值,請在當前值後鍵入新值。如果按 SPACEBAR(空格鍵)時,移動超過了 8 位界限,Debug 程式將顯示新的一行並在行首顯示新地址。
返回到前一個位元組。為此,請按 HYPHEN 鍵 (-)。可以反覆按 HYPHEN 鍵 (-) 向後移動超過多個位元組。在按 HYPHEN 時,Debug 開始新行並顯示當前地址和位元組值。
停止執行 e 命令。為此,請按 ENTER 鍵。在任何位元組位置都可以按 ENTER。
使用 list 參數
如果指定 list 參數的值,隨後的 e 命令將使用列表中的值替換現有的位元組值。如果發生錯誤,將不更改任何位元組值。
List 值可以是十六進位位元組或字串。使用空格、逗號或定位字元來分隔值。必須將字串包括在單或雙引號中。
範例
假定鍵入以下命令:
ecs:100
Debug 按下面的格式顯示第一個位元組的內容:
04BA:0100 EB.
要將該值更改為 41,請在插入點鍵入 41,如下所示:
04BA:0100 EB.41_
可以用一個 e 命令鍵入連續的位元組值。在鍵入新值後按 SPACEBAR(空格鍵),而不是按 ENTER 鍵。Debug 顯示下一個值。在此範例中,如果按三次 SPACEBAR(空格鍵),Debug 將顯示下面的值:
04BA:0100 EB.41 10. 00. BC._
要將十六進位值 BC 更改為 42,請在插入點鍵入 42,如下所示:
04BA:0100 EB.41 10. 00. BC.42_
假定決定值 10 應該是 6F。要糾正該值,請按 HYPHEN 鍵兩次以返回到地址 0101(值 10)。Debug 顯示以下內容:
04BA:0100 EB.41 10. 00. BC.42-
04BA:0102 00.-
04BA:0101 10._
在插入點鍵入 6f 更改值,如下所示:
04BA:0101 10.6f_
按 ENTER 停止 e 命令並返回到 Debug 提示符下。
以下是字串項的範例:
eds:100 "This is the text example"
該字串將從 DS:100 開始填充 24 個位元組
Debug:F(填充)
使用指定的值填充指定記憶體地區中的地址。
可以指定十六進位或 ASCII 格式表示的資料。任何以前儲存在指定位置的資料將會丟失。
f range list
參數
range
指定要填充記憶體地區的起始和結束位址,或起始地址和長度。關於有效 range 值的資訊,請單擊“相關主題”列表中的“Debug 說明”。
list
指定要輸入的資料。List 可以由十六進位數或引號包括起來的字串組成。
說明
使用 range 參數
如果 range 包含的位元組數比 list 中的數值大,Debug 將在 list 中反覆指派值,直到 range 中的所有位元組全部填充。
如果在 range 中的任何記憶體損壞或不存在,Debug 將顯示錯誤訊息並停止 f 命令。
使用 list 參數
如果 list 包含的數值多於 range 中的位元組數,Debug 將忽略 list 中額外的值。
範例
假定鍵入以下命令:
f04ba:100l100 42 45 52 54 41
作為響應,Debug 使用指定的值填充從 04BA:100 到 04BA:1FF 的記憶體位置。Debug 重複這五個值直到 100h 個位元組全部填滿為止。
Debug:G(轉向)
運行當前在記憶體中的程式。
g [=address] [breakpoints]
參數
=address
指定當前在記憶體中要開始執行的程式地址。如果不指定 address,Windows 2000 將從 CS:IP 寄存器中的當前地址開始執行程式。
breakpoints
指定可以設定為 g 命令的部分的 1 到 10 個臨時斷點。
有關執行迴圈、重複的字串指令、軟體中斷或子程式的資訊,請單擊“相關主題”列表中的 Debug P(執行)。
有關執行指令的資訊,請單擊“相關主題”列表中的 Debug T(跟蹤)。
Debug:H(十六進位)
對指定的兩個參數執行十六進位運算。
h value1 value2
參數
value1
代表從 0 到 FFFFh 範圍內的任何十六進位數字。
value2
代表從 0 到 FFFFh 範圍內第二個十六進位數字。
說明
Debug 首先將指定的兩個參數相加,然後從第一個參數中減去第二個參數。這些計算的結果顯示在一行中:先計算和,然後計算差。
範例
假定鍵入以下命令:
h19f 10a
Debug 執行運算並顯示以下結果。
02A9 0095
Debug:I(輸入)
從指定的連接埠讀取並顯示一個位元組值。
i port
參數
port
按地址指定輸入連接埠。地址可以是 16 位的值。
有關將位元組值發送到輸出連接埠的資訊,請單擊“相關主題”列表中的 Debug O(輸出)。
範例
假定鍵入以下命令:
i2f8
同時假定連接埠的位元組值是 42h。Debug 讀取該位元組,並將其值顯示如下:
42
Debug:L(載入)
將某個檔案或特定磁碟扇區的內容載入到記憶體。
要從磁碟檔案載入 BX:CX 寄存器中指定的位元組數內容,請使用以下文法:
l [address]
要略過 Windows 2000 檔案系統並直接載入特定的扇區,請使用以下文法:
l address drive start number
參數
address
指定要在其中負載檔案或扇區內容的記憶體位置。如果不指定 address,Debug 將使用 CS 寄存器中的當前地址。
drive
指定包含讀取指定扇區的磁碟的磁碟機。該值是數值型:0 = A, 1 = B, 2 = C 等。
start
指定要載入其內容的第一個扇區的十六進位數。
number
指定要載入其內容的連續扇區的十六進位數。只有要載入特定扇區的內容而不是載入 debug 命令列或最近的 Debug n(名稱)命令中指定的檔案時,才能使用 drive、start 和 number 參數。
有關指定用於 l 命令的檔案的資訊,請單擊“相關主題”列表中的 Debug n(名稱)。
有關寫入調試到磁碟的檔案的資訊,請單擊“相關主題”列表中的 Debug w(寫入)。
注意
使用不帶參數的 l 命令
當使用不帶參數的 l 命令時,在 debug 命令列上指定的檔案將載入到記憶體中,從地址 CS:100 開始。Debug 同時將 BX 和 CX 寄存器設定為載入的位元組數。如果不在 debug 命令列指定檔案,所裝入的檔案將是最近使用 n 命令經常指定的檔案。
使用具有 address 參數的 1 命令
如果使用帶 address 參數的 l 命令,Debug 將從記憶體位置 address 開始負載檔案或指定扇區的內容。
使用帶全部參數的 l 命令
如果使用帶所有參數的 l 命令,Debug 將載入指定磁碟扇區的內容而不是負載檔案。
載入特定扇區的內容
指定範圍內的每個扇區均從 drive 讀取。Debug 從 start 開始載入,直到在 number 中指定的扇區數中的內容全部被載入。
載入 .exe 檔
Debug 忽略 .exe 檔的地址 address 參數。如果指定 .exe 檔,Debug 將檔案重新置放到 .exe 檔的標題中指定的載入地址。在 .exe 檔被載入到記憶體前,標題自身從 .exe 檔脫離,因此磁碟上的 .exe 檔大小與記憶體中的不同。如果要檢查整個 .exe 檔,請使用不同的副檔名重新命名檔案。