新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 第9章 內(nèi)存操作(X86匯編教程)

第9章 內(nèi)存操作(X86匯編教程)

作者: 時(shí)間:2016-12-01 來源:網(wǎng)絡(luò) 收藏
這一章將講解匯編對(duì)內(nèi)存的操作.我之前說過,內(nèi)存操作需要2個(gè)地址.段地址和偏移地址.段地址一般放在段寄存器里,在186里面,以S結(jié)尾的寄存器就叫段寄存器(0_0!請(qǐng)不要急著寫代碼測(cè)試...),但不是每個(gè)段寄存器都能隨便改的.為什么呢?我說過:代碼也是在內(nèi)存里的,也就是說,需要一個(gè)段寄存器 和一個(gè)偏移寄存器來指向我們的代碼,還有棧(不是本章內(nèi)容),那也是一個(gè)內(nèi)存地址,也需要段寄存器和一個(gè)偏移寄存器.(我可沒說偏移地址放在偏移寄存器里,實(shí)際上我們操作內(nèi)存很少用到偏移寄存器!)

代碼地址的段寄存器為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



關(guān)鍵詞: 內(nèi)存操作X86匯編教

評(píng)論


技術(shù)專區(qū)

關(guān)閉