?? page203.html
字號(hào):
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<title>第7章 文件控制塊</title>
</head>
<body>
<style type="text/css">
body {
background-color: #c0c0c0;
}
table {
background-color: #c0c0c0;
line-height: 24px;
}
</style>
<!導(dǎo)航條>
<p><a href="content1.html">目錄</a> <a href="page202.html">上一頁</a> <a href="page204.html">下一頁</a> <a href="page207.html">下一章</a></p>
<table border=0 align="center" width=800 frame="box" rules="none">
<!標(biāo)尺行>
<tr>
<td width=3%></td><td width=6%></td><td width=1%></td> <!左側(cè)空白>
<td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td>
<td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td><td width=5%></td>
<td width=1%></td><td width=6%></td><td width=3%></td> <!右側(cè)空白>
</tr>
<!頁眉行>
<tr height=60 valign="bottom">
<td></td><td></td><td></td>
<td colspan=6><img src="icons/flag.gif"></td><td colspan=4></td><td colspan=6 align="right">第7章 文件控制塊</td> <!章節(jié)名>
<td></td><td>-203-</td><td></td> <!頁碼>
</tr>
<!頁眉線>
<tr valign="top">
<td></td><td colspan=20><hr></td><td></td>
</tr>
<!正文>
<font face="宋體" lang="ZH-CN" size=3>
<tr height=20><td colspan=22></td></tr> <!頂部空白>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
筆者使用了"TASM.EXE"這個(gè)程序作為"調(diào)試"對(duì)象,其實(shí)可以選擇任意一個(gè)".EXE"的文件。現(xiàn)在請(qǐng)大家回想一下當(dāng)一個(gè)".EXE"文件被DEBUG調(diào)入后,段寄存器DS和ES指向誰所在的段?<br>
段寄存器DS和ES指向"PSP"所在的段。我們現(xiàn)在就來看一看PSP中還有什么有用的數(shù)據(jù):
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>-d0[Enter]</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0000</td><td colspan=10>CD 20 FF 9F 00 9A F0 FE-1D F0 4F 03 92 09 8A 03</td><td></td><td colspan=5>. ........O.....</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0010</td><td colspan=10>92 09 17 03 92 09 81 09-01 04 01 00 02 FF FF FF</td><td></td><td colspan=5>................</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0020</td><td colspan=10>FF FF FF FF FF FF FF FF-FF FF FF FF 18 10 4C 01</td><td></td><td colspan=5>..............L.</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0030</td><td colspan=10>97 0D 14 00 18 00 27 10-FF FF FF FF 00 00 00 00</td><td></td><td colspan=5>......'.........</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0040</td><td colspan=10>07 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00</td><td></td><td colspan=5>................</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0050</td><td colspan=10>CD 21 CB 00 00 00 00 00-00 00 00 00 00 <u>41 41 41</u></td><td></td><td colspan=5>.!...........<u>AAA</u></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0060</td><td colspan=10>20 20 20 20 20 20 20 20-00 00 00 00 00 <u>42 42 42</u></td><td></td><td colspan=5> .....<u>BBB</u></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1027:0070</td><td colspan=10>20 20 20 20 20 20 20 20-00 00 00 00 00 00 00 00</td><td></td><td colspan=5> ........</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
"金礦"并不難發(fā)現(xiàn),注意PSP中偏移5CH和偏移6CH處的數(shù)據(jù),我們給"TASM.EXE"的兩個(gè)參數(shù)"aaa"和"bbb"就在其中。我們由此得出了第一個(gè)結(jié)論:程序所需的兩個(gè)參數(shù)出現(xiàn)在PSP偏移5CH和6CH處,而且是以大寫形式出現(xiàn)的。<br>
通過這個(gè)實(shí)驗(yàn)我們也能發(fā)覺三個(gè)問題:第一,PSP偏移5CH和6CH處存放的數(shù)據(jù)都是"0",并不是真正的命令行參數(shù),為什么要說參數(shù)出現(xiàn)在偏移5CH和6CH處呢?如果這個(gè)"0"是參數(shù)的一部分的話,那么它又有什么含義?第二,如果有更多的參數(shù)會(huì)有什么情況?第三,如果有開關(guān)符"/"又會(huì)有什么情況?為搞清這三個(gè)問題,我們?cè)僮鋈螌?shí)驗(yàn)。先看看那個(gè)奇怪的"0"是怎么回事,注意命令中加有下劃線的內(nèi)容:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>C:\ASM\>debug tasm.exe a:xxx c:yyy[Enter]</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>-d0[Enter]</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0000</td><td colspan=10>CD 20 FF 9F 00 9A F0 FE-1D F0 4F 03 92 09 8A 03</td><td></td><td colspan=5>. ........O.....</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0010</td><td colspan=10>92 09 17 03 92 09 81 09-01 04 01 00 02 FF FF FF</td><td></td><td colspan=5>................</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0020</td><td colspan=10>FF FF FF FF FF FF FF FF-FF FF FF FF 18 10 4C 01</td><td></td><td colspan=5>..............L.</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0030</td><td colspan=10>97 0D 14 00 18 00 27 10-FF FF FF FF 00 00 00 00</td><td></td><td colspan=5>......'.........</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0040</td><td colspan=10>07 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00</td><td></td><td colspan=5>................</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0050</td><td colspan=10>CD 21 CB 00 00 00 00 00-00 00 00 00 <u>01</u> 58 58 58</td><td></td><td colspan=5>.!...........xxx</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0060</td><td colspan=10>20 20 20 20 20 20 20 20-00 00 00 00 <u>03</u> 59 59 59</td><td></td><td colspan=5> .....yyy</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=2>1028:0070</td><td colspan=10>20 20 20 20 20 20 20 20-00 00 00 00 00 00 00 00</td><td></td><td colspan=5> ........</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
問題清楚了,偏移5CH和6CH處存放的數(shù)據(jù)原來是驅(qū)動(dòng)器號(hào),我們做第一次實(shí)驗(yàn)時(shí)沒有指定驅(qū)動(dòng)器,所以DOS給我們填入了"默認(rèn)"驅(qū)動(dòng)器號(hào)。這個(gè)問題就有些奇怪了,難道DOS會(huì)把我們給出的參數(shù)都當(dāng)做文件名來處理嗎?說到此,筆者認(rèn)為已經(jīng)到了真正搞清這兩個(gè)數(shù)據(jù)結(jié)構(gòu)的時(shí)候了。<br>
在PSP偏移5CH和6CH處有兩個(gè)DOS提供給我們的十分重要的數(shù)據(jù)結(jié)構(gòu),這兩個(gè)數(shù)據(jù)結(jié)構(gòu)我們稱之為"格式化未打開的FCB"。實(shí)際上每一個(gè)FCB的長度只有16個(gè)字節(jié),其結(jié)構(gòu)與一般的FCB相同。注意這兩個(gè)FCB都是"未打開的",如果我們將第一個(gè)FCB打開了,那么第二個(gè)FCB就會(huì)被覆蓋。
</td>
<td></td><td></td> <!右邊距>
</tr>
</font>
<!頁腳線>
<tr valign="top">
<td></td><td colspan=20><hr></td><td></td>
</tr>
<!頁腳>
<tr height=60 valign="top">
<td></td><td></td>
<td colspan=9><i>Copyright © 2004-2005 <a href="mailto:webmaster@nucstorm.com">Chunk Lee</a></i></td>
<td colspan=9 align="right"><i><a href="http://www.nucstorm.com" target="_top">www.nucstorm.com</a></i></td>
<td></td><td></td>
</tr>
</table>
<!導(dǎo)航條>
<p align="right"><a href="content1.html">目錄</a> <a href="page202.html">上一頁</a> <a href="page204.html">下一頁</a> <a href="page207.html">下一章</a></p>
</body>
</html>
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -