本X86匯編教程目錄 http://www.zg4o1577.cn/mcu/2619.html
這一章將講解匯編對內存的操作.我之前說過,內存操作需要2個地址.段地址和偏移地址.段地址一般放在段寄存器里,在186里面,以S結尾的寄存器就叫段寄存器(0_0!請不要急著寫代碼測試...),但不是每個段寄存器都能隨便改的.為什么呢?我說過:代碼也是在內存里的,也就是說,需要一個段寄存器 和一個偏移寄存器來指向我們的代碼,還有棧(不是本章內容),那也是一個內存地址,也需要段寄存器和一個偏移寄存器.(我可沒說偏移地址放在偏移寄存器里,實際上我們操作內存很少用到偏移寄存器!)
代碼地址的段寄存器為CS,偏移寄存器為IP
棧,段寄存器:SS,偏移寄存器:SP
恩,也就是說,CS和SS這2個段寄存器不能隨便改.
好了,接著說如何往段寄存器里寫入段地址了.說到這里不得不說CPU的一些蛋疼的地方了.暫時先說2處:
1:一般的數據操作指令,需要2個寄存器操作數的時候,不能放2個位數不同的寄存器.比如下邊的代碼是行不通的:
MOV AX,BL
2:X86有一個缺陷:不能直接MOV 段寄存器,數字,需要拿其它寄存器做中轉
這樣是不對的:
MOV DS,1800H ;X
要這樣:
MOV AX,1800H
MOV DS,AX ;√
這樣才能把1800H寫入到DS寄存器里
好了,段地址說完了,說偏移地址,這個偏移地址,載體比較多.能用部分寄存器或用直接數(就是直接上數字).
還記得內存地址算法嗎?沒錯,就是把段地址乘以16(這里的16是10進制的喲!),加上偏移地址!
在NASM匯編中,操作數為內存值的時候,用這種方式表示(把某數值寫入內存的語法↓):
MOV 要操作的數值類型 [段地址:偏移地址],數值
實例:
MOV BYTE
可見,在匯編中,用方括號表示這個操作數是內存某地址,方括號里表示地址.在指令后邊,用英文單詞表示要操作的數據類型.防止移動多余數據到內存里.
類型:
BYTE:字節形
WORD:字形
DWORD:雙字型(186用不著,因為沒這么長的寄存器)
好了,試試看吧,我們往12345H地址寫個數字進去看看:
MOV AX,1234H
MOV DS,AX
MOV BX,0005H
MOV BYTE [DS:BX],00H
編譯執行看看.
作業:把內存0000H~0004H處全部寫入00H
本章結束,交作業郵箱o7007@vip.qq.com