[基礎知識]Debug 使用簡介
發表時間:2024-01-03 來源:明輝站整理相關軟件相關文章人氣:
[摘要]調試程序DEBUG的特點: 在受控環境中測試程序; 裝入,顯示或修改任何文件; 執行DOS程序; 完成磁盤實際讀/寫操作; 建立或匯編匯編語言程序。 DEBUG的命令格式: [drive:][path] DEBUG [d:][p][filename][.ext][param...]其中: driv...
調試程序DEBUG的特點: - 在受控環境中測試程序;
- 裝入,顯示或修改任何文件;
- 執行DOS程序;
- 完成磁盤實際讀/寫操作;
- 建立或匯編匯編語言程序。
DEBUG的命令格式: [drive:][path] DEBUG [d:][p][filename][.ext][param...]
其中:
drive: 是指定DEBUG文件的磁盤驅動器標識符,DEBUG是外部DOS命令,所以必須把它從磁盤讀入內存。若未指定,DOS將使用當前默認磁盤驅動器。 path: 是DOS查找DEBUG文件的一個子目錄串表示的路徑。若未指定,DOS將使用當前工作目錄。
d: 是DEBUG將要調試的文件所在的磁盤驅動器。
p: 是查找DEBUG將要調試的文件所需的子目錄路徑,若未指定,DOS使用當前目錄。
filename[.ext] 是DEBUG將要調試的文件名。
param 是將被調試的程序(或文件)的命令行參數。
附:
DEBUG所完成的初始化動作,假定文件名沒有,啟動DEBUG:
- 段寄存器CS、DS、ES和SS置為DEBUG程序后的第一個段。
- 指令指針寄存器IP置為100H(程序段前綴PSP后的第一個語句)。
- 堆棧指針SP置為段末或COMMAND.COM暫駐部分的結束地址(其中較小的那個地址)。
- 其余通用寄存器均置為0,標志寄存器置為下述狀態。
- NV UP EI PL NE NA PO NC
如果DEBUG命令行含有文件名,段寄存器DS和ES指向PSP。寄存器BX和CX含有程序長度。
這些DEBUG命令主要參考清華大學計算機系列教材《IBM-C匯編語言程序設計》一書。
- D[address]或
- D[range]
例如,按指定范圍顯示存儲單元內容的方法為:
-D 100 120 067C:0100 C7 D7 0D 0A 32 33 33 34 - D5 C5 B4 C6 30 10 42 0C ....2334....0.B. 067C:0110 03 41 42 43 44 45 46 47 - 48 49 4A 4B 4C 4D 4E 4F .ABCDEFGHIJKLMNO 067C:0120 8B |
其中0100至0120是DEBUG顯示的單元內容。 左邊用十六進制表示每個字節,右邊用ASCII字符表示每個字節,“.”表示不可顯示的字符。這里沒有指定段地址, D命令自動顯示DS段的內容。如果只指定首地址,則顯示從首地址開始的80個字節的內容。如果完全沒有指定地址,則顯示上一個D命令的最后一個單元的內容。 這里順便提一下存儲器及其地址的分段。
計算機存儲信息的基本單位是一個二進制位,一位可存儲一個二進制數:0或1。每8位組成一個字節,位編號如下所示:
正當MS-DOS盛行的時候,PC機的字長為16位,由2個字節組成,位編號如下所示:
字 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| |
字節 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 高位字節 MSB | 低位字節 LSB |
在存儲器里以字節為單位存儲信息。為了正確地存放或取得信息,每一個字節單元給以一個存儲器地址。地址從0開始編號,順序地每次加1。在機器里,地址也是用二進制數來表示的。它是無符號整數,書寫格式為十六進制。
16位二進制可以表示2的16次方個字節單元的地址,它可表示的地址范圍應該是0-65535。為方便,存儲器的容量以2的10次方=1024為基本單位,稱為1K。這樣,65536個字節單元的存儲容量就是64K,其地址編號的范圍用16進制數表示為0-FFFFH。如下所示。
0000,0001,0002,……,……,……0009,000A,000B,000C,000D,000E,000F,
0010,0011,0012,……,……,……0019,001A,001B,001C,001D,001E,001F,
0020,0021,0022,……,……,……0029,002A,002B,002C,002D,002E,002F,
……
……
FFE0,FFE1,FFE2,……,……,……FFE9,FFEA,FFEB,FFEC,FFED,FFEE,FFEF,
FFF0,FFF1,FFF2,……,……,……FFF9,FFFA,FFFB,FFFC,FFFD,FFFE,FFFF。
一個字存入存儲器要占有相繼的二個字節,存放時,低位字節存入低地址,高位字節存入高地址,以相反的次序存入的。
存儲器的特點:它的內容是取之不盡的。從某個單元取出其內容后,該單元仍然保存著原來的內容不變,可以重復取出,只有存入新的信息之后,原來保存的內容自動丟失。
存儲器地址的分段:
前面已經提到16位字長的機器可以訪問最大存儲空間為64K字節,而PC機的最大存儲容量為1M(原MS-DOS操作系統下)。要訪問1M字節空間的存儲器必須有20位地址,用16進制數表示1M字節的地址范圍應該為00000-FFFFF。
在1M字節的存儲器里,每一個存儲單元都有一個唯一的20位地址,稱為該存儲單元的物理地址。CPU訪問存儲器時,必須先確定所要訪問的存儲單元的物理地址才能取得(或存入)該單元的內容。20位物理地址由16位段地址和16位偏移地址組成,段地址是指每一段的起始地址,由于它必須是小段的首地址,所以其低4位一定是0,這樣就可以規定段地址只取段起始地址的高16位值。偏移地址則是指在段內相對于段起始地址的偏移值。這樣,物理地址的計算方法如下:
把段地址左移4位再加上偏移地址值就形成物理地址。或寫成: 16dX段地址+偏移地址=物理地址
每個存儲單元只有唯一的物理地址,但它卻可由不同的段地址和不同的偏移地址組成。
在PC機中,有四個專門存放段地址的寄存器,稱為段寄存器。它們是代碼段CS(Code Segment)、數據段DS(Data Segment)、堆棧段SS(Stack Segment)和附加段ES(Extra Segment)寄存器。每個段寄存器可以確定一個段的起始地址,而這些段則各有各的用途。代碼段是存放當前正在運行的程序。數據段存放當前運行程序所用的數據,如果程序中使用了串處理指令,則其源操作數也存放在數據段中。堆棧段定義了堆棧的所在區域,堆棧是一種數據結構,它是一個比較特殊的數據段。附加段是附加的數據段,它是一個輔助的數據區,也是串處理指令的目的操作數存放區。還有四個通用數據寄存器AX、BX、CX、DX;四個指針及變址寄存器SP、BP、SI、DI;控制寄存器包括IP(指令指針寄存器)和PSW程序狀態字寄存器。這些將專門開辟一頁詳加介紹。
第一種格式可以用給定的內容表來替代指定范圍的存儲單元內容。命令格式為:
-E address [list]
例如,-E DS:100 F3'XYZ'8D
其中F3,‘X’,‘Y’,‘Z’和8D各占一個字節,該命令可以用這五個字節來替代存儲單元DS:0100到0104的原先的內容。
第二種格式則是采用逐個單元相繼修改的方法。命令格式為:
-E address
例如,-E CS:100
則可能顯示為:
18E4:0100 89. -
如果需要把該單元的內容修改為78,則可以直接鍵入78,再按空格鍵可接著顯示下一個單元的內容,這樣可以不斷修改相繼單元的內容,直到Enter鍵結束該命令為止。
-F range list
例如,-F 4BA:0100 5 F3'XYZ'8D
使04BA:0100-0104單元包含指定的五個字節的內容。如果list中的字節數超過指定的范圍,則忽略超過的項;如果list的字節數小于指定范圍,則重復使用list填入,直到填滿指定的所有單元為止。
☆ 檢查和修改寄存器內容的命令R(Register),它有三種格式如下: |
- 顯示CPU內所有寄存器內容和標志位狀態,其格式為:
-R
例如,
-r
AX=0000 BX=0000 CX=010A DX=0000 SP=FFFE BP=0000 SI=0000 DI=0000
DS=18E4 ES=18E4 SS=18E4 CS=18E4 IP=0100 NV UP DI PL NZ NA PO NC
18E4:0100 C70604023801 MOV WORD PTR[0204],0138 DS:0204=0000
其中標志位狀態的含義可見下表:
標 志 名 | 標志為1 | 標志為0 |
OF DF IF SF ZF AF PF CF | 溢出(是/否) 方向(減量/增量) 中斷(允許/關閉) 符號(負/正) 零(是/否) 輔助進位(是/否) 奇偶(偶/奇) 進位(是/否 | OV DN EI NG ZR AC PE CY | NV UP DI PL NZ NA PO NC |
-R register name
例如,鍵入
-r ax
系統將響應如下:
AX F1F4
:
即AX寄存器的當前內容為F1F4,如不修改則按Enter鍵,否則,鍵入欲修改的內容如:
-r bx
BX 0369
:059F
則把BX寄存器的當前內容修改為059F。
-RF
系統將響應,如:
OV DN EI NG ZR AC PE CY -
此時如不修改其內容可按Enter鍵,否則,建入欲修改的內容,如:
OV DN EI NG ZR AC PE CY - PONZDINV
即可,鍵入的順序是任意的。
其中,地址1指定了運行的起始地址,如不指定則從當前的CS:IP開始運行。后面的地址均為斷點地址,當指令執行到斷點時,就停止執行并顯示當前所有寄存器及標志位的內容,和下一條將要執行的指令。
-T[=address]
從指定地址起執行一條指令后停下來,顯示所有寄存器內空及標志位的值。如未指定則從當前的CS:IP開始執行。
-T[=address][value]
從指定地址起執行n條指令后停下來,n由value指定。
-A [address]
該命令允許鍵入匯編語言語句,并能把它們匯編成機器代碼,相繼地存放在從指定地址開始的存儲區中。必須注意:DEBUG把鍵入的數字均看成十六進制數,所以如要鍵入十進制數,則其后應加以說明,如100D。
☆ 反匯編命令U(Unassemble),有兩種格式: |
-U[range]
例如:
-u 100
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
18E4:0112 BB0402 MOV BX,0204
18E4:0115 E80200 CALL 011A
18E4:0118 CD20 INT 20
18E4:011A 50 PUSH AX
18E4:011B 51 PUSH CX
18E4:011C 56 PUSH SI
18E4:011D 57 PUSH DI
18E4:011E 8B37 MOV SI,[BX]
如果地址被省略則從上一個U命令的最后一條指令的下一個單元開始顯示32個字節。
-U[range]
例如:
-u 100 10C
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
或
-u 100 112
18E4:0100 C70604023801 MOV WORD PTR[0204],0138
18E4:0106 C70606020002 MOV WORD PTR[0206],0200
18E4:010C C70608020202 MOV WORD PTR[0208],0202
這兩種格式是等效的。
-N filespecs [filespecs]
命令把兩個文件標識符格式化在CS:5CH和CS:6CH的兩個文件控制塊中,以便在其后用L或W命令把文件裝入或存盤。filespecs的格式可以是:
[d:][path] filename[.ext]
例如:
-N myprog
-L
-
可把文件myprog裝入存儲器。
- 把磁盤上指定扇區范圍的內容裝入到存儲器從指定地址開始的區域中。其格式為:
-L[address [drive sector sector]]
-L[address]
此命令裝入已在CS:5CH中格式化了的文件控制塊所指定的文件。如未指定地址,則裝入CS:0100開始的存儲區中。
-W address drive sector sector
-W [address]
此命令把指定的存儲區中的數據寫入由CS:5CH處的文件控制塊所指定的文件中。如未指定地址則數據從CS:0100開始。要寫入文件的字節數應先放入BX和CX中。
-Q
它退出DEBUG,返回DOS。本命令無存盤功能,如需存盤應先使用W命令。