第9章 內(nèi)存操作(X86匯編教程)
代碼地址的段寄存器為CS,偏移寄存器為IP
本文引用地址:http://m.butianyuan.cn/article/201612/324267.htm棧,段寄存器:SS,偏移寄存器:SP
恩,也就是說,CS和SS這2個(gè)段寄存器不能隨便改.
好了,接著說如何往段寄存器里寫入段地址了.說到這里不得不說CPU的一些蛋疼的地方了.暫時(shí)先說2處:
1:一般的數(shù)據(jù)操作指令,需要2個(gè)寄存器操作數(shù)的時(shí)候,不能放2個(gè)位數(shù)不同的寄存器.比如下邊的代碼是行不通的:
MOV AX,BL
2:X86有一個(gè)缺陷:不能直接MOV 段寄存器,數(shù)字,需要拿其它寄存器做中轉(zhuǎn)
這樣是不對(duì)的:
MOV DS,1800H;X
要這樣:
MOV AX,1800H
MOV DS,AX;√
這樣才能把1800H寫入到DS寄存器里
好了,段地址說完了,說偏移地址,這個(gè)偏移地址,載體比較多.能用部分寄存器或用直接數(shù)(就是直接上數(shù)字).
還記得內(nèi)存地址算法嗎?沒錯(cuò),就是把段地址乘以16(這里的16是10進(jìn)制的喲!),加上偏移地址!
在NASM匯編中,操作數(shù)為內(nèi)存值的時(shí)候,用這種方式表示(把某數(shù)值寫入內(nèi)存的語法↓):
MOV 要操作的數(shù)值類型 [段地址:偏移地址],數(shù)值
實(shí)例:
MOV BYTE
可見,在匯編中,用方括號(hào)表示這個(gè)操作數(shù)是內(nèi)存某地址,方括號(hào)里表示地址.在指令后邊,用英文單詞表示要操作的數(shù)據(jù)類型.防止移動(dòng)多余數(shù)據(jù)到內(nèi)存里.
類型:
BYTE:字節(jié)形
WORD:字形
DWORD:雙字型(186用不著,因?yàn)闆]這么長(zhǎng)的寄存器)
好了,試試看吧,我們往12345H地址寫個(gè)數(shù)字進(jìn)去看看:
MOV AX,1234H
MOV DS,AX
MOV BX,0005H
MOV BYTE [DS:BX],00H
編譯執(zhí)行看看.
作業(yè):把內(nèi)存0000H~0004H處全部寫入00H
評(píng)論