?? page5.html
字號:
<html>
<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<title>第1章 匯編語言基礎知識</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="page4.html">上一頁</a> <a href="page6.html">下一頁</a> <a href="page11.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">第1章 匯編語言基礎知識</td> <!章節名>
<td></td><td>-5-</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>
③ 對給定的數作什么操作可得到二進制數01001011。<br>
④ 若把給定的數同00100010作XOR操作,將得到什么結果。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18><font face="黑體">解:</font>
① 將OR操作的結果同給定的數相比,不難發現只要把給定數字的bit0,bit3位置成1,其它位狀態保持不變,即可得出結果。因此可很容易求出八位二進制數00001001,并可驗證:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10110100</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right"><u>OR) 00001001</u></td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10111101</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
可見,OR操作可以方便的將某個二進制數的特定位置成"1"而保存其它位不變。只要取另一個二進制數,讓這個數中的相應數位--即和給定的數中要改變的數位相對應的位--為"1",而其它位為"0",即可達到目的。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
② 將AND操作的結果同給定的數相比,可以看出只要把給定數字的bit2,bit7位置成0,其它位保持不變,即得出結果。因此可很容易求出八位二進制數01111011,并且可以驗證:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10110100</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right"><u>AND) 01111011</u></td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">00110000</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
可見,和OR操作相對應,AND操作可以把某個二進制數的特定位置"0"而保持其它位不變。只要取另一個二進制數,讓這個數的相應位為"0",而其它位為"1",即可達到目的。
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
③ 比較結果和給定數,可看出將已知數所有位取相反狀態,可得到結果。因此可用NOT操作,即
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right"><u>NOT) 10110100</u></td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">01001011</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
④ 將兩個數作XOR操作
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10110100</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right"><u>XOR) 00100010</u></td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10010110</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
把得到的結果10010110同已知數相比較,可以看出只要將已知數的bit1,bit5兩位取反,就能得出結果。將(3)和(4)進行比較,可以發現這樣一個規律:NOT操作可以將給定數的所有位取反,而XOR操作可以將給定數的特定位取反;進一步分析(4),不難看出若把所得到的結果10010110和00100010再作一次XOR操作:
</td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10010110</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right"><u>XOR) 00100010</u></td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=4></td>
<td colspan=4 align="right">10110100</td>
<td colspan=10></td>
<td></td><td></td> <!右邊距>
</tr>
<tr>
<td></td><td></td> <!左邊距>
<td colspan=18>
又能得到了已知的數。即取反后的數位又重新恢復原狀態。因此我們說,XOR操作可以反復改變給定數中的特定位狀態。
</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="page4.html">上一頁</a> <a href="page6.html">下一頁</a> <a href="page11.html">下一章</a></p>
</body>
</html>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -