[基礎(chǔ)知識(shí)]Debug 使用簡(jiǎn)介
發(fā)表時(shí)間:2024-01-03 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]調(diào)試程序DEBUG的特點(diǎn): 在受控環(huán)境中測(cè)試程序; 裝入,顯示或修改任何文件; 執(zhí)行DOS程序; 完成磁盤實(shí)際讀/寫操作; 建立或匯編匯編語(yǔ)言程序。 DEBUG的命令格式: [drive:][path] DEBUG [d:][p][filename][.ext][param...]其中: driv...
調(diào)試程序DEBUG的特點(diǎn): - 在受控環(huán)境中測(cè)試程序;
- 裝入,顯示或修改任何文件;
- 執(zhí)行DOS程序;
- 完成磁盤實(shí)際讀/寫操作;
- 建立或匯編匯編語(yǔ)言程序。
DEBUG的命令格式: [drive:][path] DEBUG [d:][p][filename][.ext][param...]
其中:
drive: 是指定DEBUG文件的磁盤驅(qū)動(dòng)器標(biāo)識(shí)符,DEBUG是外部DOS命令,所以必須把它從磁盤讀入內(nèi)存。若未指定,DOS將使用當(dāng)前默認(rèn)磁盤驅(qū)動(dòng)器。 path: 是DOS查找DEBUG文件的一個(gè)子目錄串表示的路徑。若未指定,DOS將使用當(dāng)前工作目錄。
d: 是DEBUG將要調(diào)試的文件所在的磁盤驅(qū)動(dòng)器。
p: 是查找DEBUG將要調(diào)試的文件所需的子目錄路徑,若未指定,DOS使用當(dāng)前目錄。
filename[.ext] 是DEBUG將要調(diào)試的文件名。
param 是將被調(diào)試的程序(或文件)的命令行參數(shù)。
附:
DEBUG所完成的初始化動(dòng)作,假定文件名沒有,啟動(dòng)DEBUG:
- 段寄存器CS、DS、ES和SS置為DEBUG程序后的第一個(gè)段。
- 指令指針寄存器IP置為100H(程序段前綴PSP后的第一個(gè)語(yǔ)句)。
- 堆棧指針SP置為段末或COMMAND.COM暫駐部分的結(jié)束地址(其中較小的那個(gè)地址)。
- 其余通用寄存器均置為0,標(biāo)志寄存器置為下述狀態(tài)。
- NV UP EI PL NE NA PO NC
如果DEBUG命令行含有文件名,段寄存器DS和ES指向PSP。寄存器BX和CX含有程序長(zhǎng)度。
這些DEBUG命令主要參考清華大學(xué)計(jì)算機(jī)系列教材《IBM-C匯編語(yǔ)言程序設(shè)計(jì)》一書。
☆ 顯示存儲(chǔ)單元的命令D(DEBUG),格式為: |
- D[address]或
- D[range]
例如,按指定范圍顯示存儲(chǔ)單元內(nèi)容的方法為:
-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顯示的單元內(nèi)容。 左邊用十六進(jìn)制表示每個(gè)字節(jié),右邊用ASCII字符表示每個(gè)字節(jié),“.”表示不可顯示的字符。這里沒有指定段地址, D命令自動(dòng)顯示DS段的內(nèi)容。如果只指定首地址,則顯示從首地址開始的80個(gè)字節(jié)的內(nèi)容。如果完全沒有指定地址,則顯示上一個(gè)D命令的最后一個(gè)單元的內(nèi)容。 這里順便提一下存儲(chǔ)器及其地址的分段。
計(jì)算機(jī)存儲(chǔ)信息的基本單位是一個(gè)二進(jìn)制位,一位可存儲(chǔ)一個(gè)二進(jìn)制數(shù):0或1。每8位組成一個(gè)字節(jié),位編號(hào)如下所示:
正當(dāng)MS-DOS盛行的時(shí)候,PC機(jī)的字長(zhǎng)為16位,由2個(gè)字節(jié)組成,位編號(hào)如下所示:
字 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| |
字節(jié) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 高位字節(jié) MSB | 低位字節(jié) LSB |
在存儲(chǔ)器里以字節(jié)為單位存儲(chǔ)信息。為了正確地存放或取得信息,每一個(gè)字節(jié)單元給以一個(gè)存儲(chǔ)器地址。地址從0開始編號(hào),順序地每次加1。在機(jī)器里,地址也是用二進(jìn)制數(shù)來(lái)表示的。它是無(wú)符號(hào)整數(shù),書寫格式為十六進(jìn)制。
16位二進(jìn)制可以表示2的16次方個(gè)字節(jié)單元的地址,它可表示的地址范圍應(yīng)該是0-65535。為方便,存儲(chǔ)器的容量以2的10次方=1024為基本單位,稱為1K。這樣,65536個(gè)字節(jié)單元的存儲(chǔ)容量就是64K,其地址編號(hào)的范圍用16進(jìn)制數(shù)表示為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,F(xiàn)FE1,F(xiàn)FE2,……,……,……FFE9,F(xiàn)FEA,F(xiàn)FEB,F(xiàn)FEC,F(xiàn)FED,F(xiàn)FEE,F(xiàn)FEF,
FFF0,F(xiàn)FF1,F(xiàn)FF2,……,……,……FFF9,F(xiàn)FFA,F(xiàn)FFB,F(xiàn)FFC,F(xiàn)FFD,F(xiàn)FFE,F(xiàn)FFF。
一個(gè)字存入存儲(chǔ)器要占有相繼的二個(gè)字節(jié),存放時(shí),低位字節(jié)存入低地址,高位字節(jié)存入高地址,以相反的次序存入的。
存儲(chǔ)器的特點(diǎn):它的內(nèi)容是取之不盡的。從某個(gè)單元取出其內(nèi)容后,該單元仍然保存著原來(lái)的內(nèi)容不變,可以重復(fù)取出,只有存入新的信息之后,原來(lái)保存的內(nèi)容自動(dòng)丟失。
存儲(chǔ)器地址的分段:
前面已經(jīng)提到16位字長(zhǎng)的機(jī)器可以訪問最大存儲(chǔ)空間為64K字節(jié),而PC機(jī)的最大存儲(chǔ)容量為1M(原MS-DOS操作系統(tǒng)下)。要訪問1M字節(jié)空間的存儲(chǔ)器必須有20位地址,用16進(jìn)制數(shù)表示1M字節(jié)的地址范圍應(yīng)該為00000-FFFFF。
在1M字節(jié)的存儲(chǔ)器里,每一個(gè)存儲(chǔ)單元都有一個(gè)唯一的20位地址,稱為該存儲(chǔ)單元的物理地址。CPU訪問存儲(chǔ)器時(shí),必須先確定所要訪問的存儲(chǔ)單元的物理地址才能取得(或存入)該單元的內(nèi)容。20位物理地址由16位段地址和16位偏移地址組成,段地址是指每一段的起始地址,由于它必須是小段的首地址,所以其低4位一定是0,這樣就可以規(guī)定段地址只取段起始地址的高16位值。偏移地址則是指在段內(nèi)相對(duì)于段起始地址的偏移值。這樣,物理地址的計(jì)算方法如下:
把段地址左移4位再加上偏移地址值就形成物理地址。或?qū)懗桑?nbsp; 16dX段地址+偏移地址=物理地址
每個(gè)存儲(chǔ)單元只有唯一的物理地址,但它卻可由不同的段地址和不同的偏移地址組成。
在PC機(jī)中,有四個(gè)專門存放段地址的寄存器,稱為段寄存器。它們是代碼段CS(Code Segment)、數(shù)據(jù)段DS(Data Segment)、堆棧段SS(Stack Segment)和附加段ES(Extra Segment)寄存器。每個(gè)段寄存器可以確定一個(gè)段的起始地址,而這些段則各有各的用途。代碼段是存放當(dāng)前正在運(yùn)行的程序。數(shù)據(jù)段存放當(dāng)前運(yùn)行程序所用的數(shù)據(jù),如果程序中使用了串處理指令,則其源操作數(shù)也存放在數(shù)據(jù)段中。堆棧段定義了堆棧的所在區(qū)域,堆棧是一種數(shù)據(jù)結(jié)構(gòu),它是一個(gè)比較特殊的數(shù)據(jù)段。附加段是附加的數(shù)據(jù)段,它是一個(gè)輔助的數(shù)據(jù)區(qū),也是串處理指令的目的操作數(shù)存放區(qū)。還有四個(gè)通用數(shù)據(jù)寄存器AX、BX、CX、DX;四個(gè)指針及變址寄存器SP、BP、SI、DI;控制寄存器包括IP(指令指針寄存器)和PSW程序狀態(tài)字寄存器。這些將專門開辟一頁(yè)詳加介紹。
☆ 修改存儲(chǔ)單元內(nèi)容的命令有兩種 |
第一種格式可以用給定的內(nèi)容表來(lái)替代指定范圍的存儲(chǔ)單元內(nèi)容。命令格式為:
-E address [list]
例如,-E DS:100 F3'XYZ'8D
其中F3,‘X’,‘Y’,‘Z’和8D各占一個(gè)字節(jié),該命令可以用這五個(gè)字節(jié)來(lái)替代存儲(chǔ)單元DS:0100到0104的原先的內(nèi)容。
第二種格式則是采用逐個(gè)單元相繼修改的方法。命令格式為:
-E address
例如,-E CS:100
則可能顯示為:
18E4:0100 89. -
如果需要把該單元的內(nèi)容修改為78,則可以直接鍵入78,再按空格鍵可接著顯示下一個(gè)單元的內(nèi)容,這樣可以不斷修改相繼單元的內(nèi)容,直到Enter鍵結(jié)束該命令為止。
-F range list
例如,-F 4BA:0100 5 F3'XYZ'8D
使04BA:0100-0104單元包含指定的五個(gè)字節(jié)的內(nèi)容。如果list中的字節(jié)數(shù)超過指定的范圍,則忽略超過的項(xiàng);如果list的字節(jié)數(shù)小于指定范圍,則重復(fù)使用list填入,直到填滿指定的所有單元為止。
☆ 檢查和修改寄存器內(nèi)容的命令R(Register),它有三種格式如下: |
- 顯示CPU內(nèi)所有寄存器內(nèi)容和標(biāo)志位狀態(tài),其格式為:
-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
其中標(biāo)志位狀態(tài)的含義可見下表:
標(biāo) 志 名 | 標(biāo)志為1 | 標(biāo)志為0 |
OF DF IF SF ZF AF PF CF | 溢出(是/否) 方向(減量/增量) 中斷(允許/關(guān)閉) 符號(hào)(負(fù)/正) 零(是/否) 輔助進(jìn)位(是/否) 奇偶(偶/奇) 進(jìn)位(是/否 | OV DN EI NG ZR AC PE CY | NV UP DI PL NZ NA PO NC |
- 顯示和修改某個(gè)寄存器內(nèi)容,其格式為:
-R register name
例如,鍵入
-r ax
系統(tǒng)將響應(yīng)如下:
AX F1F4
:
即AX寄存器的當(dāng)前內(nèi)容為F1F4,如不修改則按Enter鍵,否則,鍵入欲修改的內(nèi)容如:
-r bx
BX 0369
:059F
則把BX寄存器的當(dāng)前內(nèi)容修改為059F。
- 顯示和修改標(biāo)志位狀態(tài),命令格式為:
-RF
系統(tǒng)將響應(yīng),如:
OV DN EI NG ZR AC PE CY -
此時(shí)如不修改其內(nèi)容可按Enter鍵,否則,建入欲修改的內(nèi)容,如:
OV DN EI NG ZR AC PE CY - PONZDINV
即可,鍵入的順序是任意的。
其中,地址1指定了運(yùn)行的起始地址,如不指定則從當(dāng)前的CS:IP開始運(yùn)行。后面的地址均為斷點(diǎn)地址,當(dāng)指令執(zhí)行到斷點(diǎn)時(shí),就停止執(zhí)行并顯示當(dāng)前所有寄存器及標(biāo)志位的內(nèi)容,和下一條將要執(zhí)行的指令。
-T[=address]
從指定地址起執(zhí)行一條指令后停下來(lái),顯示所有寄存器內(nèi)空及標(biāo)志位的值。如未指定則從當(dāng)前的CS:IP開始執(zhí)行。
-T[=address][value]
從指定地址起執(zhí)行n條指令后停下來(lái),n由value指定。
☆ 匯編命令A(yù)(Assemble),其格式為: |
-A [address]
該命令允許鍵入?yún)R編語(yǔ)言語(yǔ)句,并能把它們匯編成機(jī)器代碼,相繼地存放在從指定地址開始的存儲(chǔ)區(qū)中。必須注意:DEBUG把鍵入的數(shù)字均看成十六進(jìn)制數(shù),所以如要鍵入十進(jìn)制數(shù),則其后應(yīng)加以說(shuō)明,如100D。
☆ 反匯編命令U(Unassemble),有兩種格式: |
- 從指定地址開始,反匯編32個(gè)字節(jié),其格式為:
-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]
如果地址被省略則從上一個(gè)U命令的最后一條指令的下一個(gè)單元開始顯示32個(gè)字節(jié)。
- 對(duì)指定范圍內(nèi)的存儲(chǔ)單元進(jìn)行反匯編,格式為:
-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]
命令把兩個(gè)文件標(biāo)識(shí)符格式化在CS:5CH和CS:6CH的兩個(gè)文件控制塊中,以便在其后用L或W命令把文件裝入或存盤。filespecs的格式可以是:
[d:][path] filename[.ext]
例如:
-N myprog
-L
-
可把文件myprog裝入存儲(chǔ)器。
- 把磁盤上指定扇區(qū)范圍的內(nèi)容裝入到存儲(chǔ)器從指定地址開始的區(qū)域中。其格式為:
-L[address [drive sector sector]]
-L[address]
此命令裝入已在CS:5CH中格式化了的文件控制塊所指定的文件。如未指定地址,則裝入CS:0100開始的存儲(chǔ)區(qū)中。
- 把數(shù)據(jù)寫入磁盤的指定扇區(qū)。其格式為:
-W address drive sector sector
- 把數(shù)據(jù)寫入指定的文件中。其格式為:
-W [address]
此命令把指定的存儲(chǔ)區(qū)中的數(shù)據(jù)寫入由CS:5CH處的文件控制塊所指定的文件中。如未指定地址則數(shù)據(jù)從CS:0100開始。要寫入文件的字節(jié)數(shù)應(yīng)先放入BX和CX中。
-Q
它退出DEBUG,返回DOS。本命令無(wú)存盤功能,如需存盤應(yīng)先使用W命令。