?? page300.html
字號:
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<title>第11章 更高級的技術</title>
</head>
<body>
<style type="text/css">
body {
background-color: #c0c0c0;
}
table {
background-color: #c0c0c0;
line-height: 24px;
}
</style>
<!導航條>
<p><a href="content1.html">目錄</a> <a href="page299.html">上一頁</a> <a href="page301.html">下一頁</a> <a href="page328.html">附錄A</a></p>
<table border=0 align="center" width=800 frame="box" rules="none">
<!標尺行>
<tr>
<td width=3%></td><td width=6%></td><td width=1%></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=5%></td>
<td width=1%></td><td width=6%></td><td width=3%></td>
</tr>
<!頁眉行>
<tr height=60 valign="bottom">
<td></td><td>-300-</td><td></td> <!頁碼>
<td colspan=6>PC機匯編語言實戰精解</td><td colspan=4></td><td colspan=6 align="right"><img src="icons/flag.gif"></td> <!書名>
<td></td><td></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=2>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
code<br>
<br>
</td>
<td colspan=2>
mov<br>
mov<br>
mov<br>
mov<br>
int<br>
<br>
mov<br>
int<br>
ends<br>
end
</td>
<td colspan=5>
word ptr [old09],bx<br>
word ptr [old09+2],es<br>
ax,2509h<br>
dx,offset new09<br>
21h<br>
<br>
dx,offset install<br>
27h<br>
<br>
start
</td>
<td colspan=9>
;將原09H中斷向量存入內存<br>
<br>
;設置新的09H中斷向量<br>
<br>
<br>
<br>
;結束并駐留內存<br>
<br>
<br>
<br>
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
將這個程序編譯連接成COM文件,運行之后就會發現鍵盤的工作與原先一模一樣,唯一的不同就是F11和F12這兩個功能鍵有作用了。其實這個程序并沒有什么特殊的技術,我們只不過是采用了DOS提供的35H功能預先取得了原09H中斷服務程序的入口地址,并將其保存在一個雙字的數據區內:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=3 align="center"><img src="icons/note.gif"></td>
<td colspan=15>
功能號:35H<br>
用 途:取得某個中斷服務程序的入口地址<br>
參 數:AH=35H<br>
AL=中斷號<br>
調 用:INT 21H<br>
返 回:ES=中斷服務程序入口段地址<br>
BX=中斷服務程序入口偏移地址
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
注意一下程序中取代"IRET"的指令"JMP DWORD PTR CS:[OLD09]",我們前面講過許多應用于MOV等數據傳送指令的尋址方式同樣適用于JMP、CALL等轉移指令,在這個程序中指令JMP可看作是應用了"存儲器直接尋址"方式完成"遠程"轉移。關于這個指令有三個關鍵之處:<br>
<font face="楷體_GB2312">
?、?注意PTR操作符前的"類型"是"DWORD(Double WORD)",不要想當然地寫成"WORD PTR"或"FAR PTR"。寫成"WORD PTR"指令本身并沒錯,但是它不能完成"遠程"轉移。至于"FAR PTR"則是完完全全的不對。<br>
② 注意明確指定段寄存器是CS,因為原服務程序入口地址和新編的中斷服務程序代碼是在一個段內,而CPU進入中斷服務程序后只有CS寄存器指向這個段,其它段寄存器還都是被中斷的程序設置的值。<br>
?、?注意預先保存原中斷服務程序入口地址時要把偏移地址放在低字位置,段地址放在高字位置。<br>
</font>
?。?)05H中斷<br>
嚴格地說這個中斷并不是一個硬件中斷,盡管這個中斷是由[PrtSc]鍵激發的。實際上這個中斷是由09H中斷服務程序調用而產生,當[PrtSc]鍵按下之后,09H中斷服務程序檢測到鍵盤發出的掃描碼是[PrtSc]鍵,它就會執行一條"INT 05"指令,從而產生05H中斷。<br>
系統為05H中斷提供的服務程序可以將屏幕上顯示的內容輸出到打印機,完成屏幕的"硬拷貝"。很多抓圖程序都是通過重編05H中斷服務程序的方法實現其功能,我們下面給出的程序就是通過這種方法實現"拷屏"的:
</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>
<!導航條>
<p align="right"><a href="content1.html">目錄</a> <a href="page299.html">上一頁</a> <a href="page301.html">下一頁</a> <a href="page328.html">附錄A</a></p>
</body>
</html>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -