?? page13.html
字號:
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<title>第2章 開始設計程序</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="page12.html">上一頁</a> <a href="page14.html">下一頁</a> <a href="page27.html">下一章</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></td><td></td>
<td colspan=6><img src="icons/flag.gif"></td><td colspan=4></td><td colspan=6 align="right">第2章 開始設計程序</td> <!章節名>
<td></td><td>-13-</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><img src="icons/P2_4_DX.gif"></td>
<td colspan=17>
DX是一個一般用途的數據寄存器,通常用于臨時保存數據。有時它也和AX一起應用,用于記錄32bit數據的高16bit。同時DX在端口輸入/輸出時也有特殊用途,此用途將在后交介紹。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
前面所講的四個寄存器都是16位的,有時程序也需要使用8位的數據,因此,這四個16位通用寄存器都可以拆分成兩個8位寄存器。即它們的高8位和低8位可單獨使用。這兩個部分都有專門的名字,我們用字母"H(High)"表示高8位,用"L(Low)"表示低8位。因此,對于AX來講,它的高8位被稱為AH,低8位稱為AL。同理,BX、CX、DX均可分成"*H"、"*L"分別使用。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
<font face="黑體">(2) 邏輯地址</font><br>
出現在左下角的16進制數字就是目前即將存放程序代碼的內存起始地址。在前面一章里討論數據存儲時曾說到過,每個內存單元都有一個地址。對于8086/88來說,它的內存地址范圍是00000--0FFFFFH。即它產生20位的地址。這20位的地址我們一般稱其為"物理地址"。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4 align="center"><img src="figures/F2_3.gif"><br><font face="楷體_GB2312" size=3>圖2-1 內存的組織</font></td>
<td colspan=14>
但實際上CPU內部并沒有20位的寄存器來保存它所需的地址,這是因為在一個硅片上制造20位的寄存器是很不方便的。因此在設計8086/88時,技術人員對這1MB的內存做了如下所述的重新編排。<br>
首先,我們把1MB內存分成了一些相互重疊的存儲塊,從地址00000開始,每隔16個字節做為一個塊的開始,整個內存分為64K個塊,這些存儲塊被稱為"存儲段"。<br>
每個塊的長度是64KB。對于相鄰的兩段而言,前一段的后64K-16個字節和后一段的前64K-16字節是重疊的。<br>
每一個段都有一個編號,這個編號就是"段地址"。因此如果想找到內存中的某一單元,首先應給出這個單元所在的任一個段的段地址,然后再給出這個單元在所選段內的"偏移量"(距段首的距離),就可找到這個內存單元。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
習慣上一般把這種用"段地址:偏移量"表示內存單元所在位置的形式稱為"邏輯地址"。因為各個段間有部分重疊,所以同樣的一個內存單元有多種不同的"段:偏移"表示。例如對于物理地址為00010H的內存單元,若在內存第0段中表示,應該是0000:0010H;而在內存第1段中表示,則成了0001:0000H。<br>
邏輯地址和物理地址之間的轉換轉換關系也很簡單,由于段地址起始于16字節的整數倍,因此若要找到某個段的起始地址,只須將該段的段地址乘以16即可;不同的單元有不同的段內偏移量,將偏移量和段起始物理地址相加,就得到任一內存單元的物理地址。<br>
例如邏輯地址0000:0010H對應的物理地址是0′10H+10H=00010H;而邏輯地址0001:0000對應的物理地址是1′10H+0=00010H,這兩個邏輯地址表示內存中同一個單元。注意這種轉換是由CPU內部電路自動完成的,對于匯編程序而言則只需使用邏輯地址即可。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
<font face="黑體">(3) 段寄存器(Segment register)</font><br>
段寄存器就是用來存儲內存單元的段地址的。CPU中共有四個段寄存器DS、ES、CS和SS,分別介紹如下:
</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="page12.html">上一頁</a> <a href="page14.html">下一頁</a> <a href="page27.html">下一章</a></p>
</body>
</html>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -