luqingfei@C++

为中华之崛起而崛起!
兼听则明,偏听则暗。

汇编语言--数据处理的两个基本问题

 

数据处理的两个基本问题

 

汇编语言中数据位置的表达

在汇编语言中如何表达数据的位置?

汇编语言中用三个概念来表达数据的位置:

1) 立即数(idata

2) 寄存器

3) 内存(段地址SA和偏移地址EA

 

 

寻址方式

当数据存放在内存中的时候,我们可以用多种方式来给定这个内存单元的偏移地址,这种定位内存单元的方法一般被称为寻址方式。

 

 

指令要处理的数据有多长?

8086CPU的指令,可以处理两种尺寸的数据,byteword

所以在机器指令中要指明指令进行的是字操作还是字节操作。

1) 通过寄存器名指明要处理的数据的尺寸。

2) 在没寄存器名存在的情况下,用操作符X ptr指明内存单元的长度,X在汇编指令中可以为wordbyte

3) 其他方法,有些指令默认了访问的是字单元还是字节单元,比如,push[1000H]就不用指明访问的是字单元还是字节单元,因为push指令只进行字操作。

 

 

寻址方式的综合应用

8086CPU提供的如[bx+si+idata]的寻址方式为结构化数据的处理提供了方便。

 

 

div指令

div是除法指令。

1) 除数:有8位和16位两种,在一个寄存器或内存单元中。

2) 被除数:默认放在AXDXAX中,如果除数为8位,被除数则为16位,默认在AX中存放;如果除数为16位,被除数则为32位,在DXAX中存放,DX存放高16位,AX存放低16位。

3) 结果:如果除数为8位,则AL存储除法操作的商,AH存储除法操作的余数;如果除数为16位,同AX存储除法操作的商,DX存储除法操作的余数。

格式如下:

div reg

div 内存单元

 

div byte ptr ds:[0]     ;除数指定为8

(al) = (ax)/((ds)*16+0)的商;

(ah)=(ax)/((ds)*16+0)的余数。

 

div word ptr es:[0]

(ax) =( (dx)*10000H+(ax))/((ex)*16+0)的商;

(dx)= ( (dx)*10000H+(ax))/((ex)*16+0)的余数。

 

div byte ptr [bx+si+8]

(al)=(ax)/((ds)*16+(bx)+(si)+8)的商;

(ah)= (ax)/((ds)*16+(bx)+(si)+8)的余数。

 

div word ptr [bx+si+8]

(ax)=((dx)*10000H)+(ax))/((ds)*16+(bx)+(si)+8))的商;

(ax)=((dx)*10000H)+(ax))/((ds)*16+(bx)+(si)+8))的余数。

 

 

实践:100001/100

被除数100001大于65535FFFF、十六位),不能用ax寄存器存放,所以我们只能用dxax两个寄存器联合存放100001,也就是说要进行16位的除法,除数100小于255,可以在一个8位寄存器中存放,但是,因为被除数是32位的,除数应为16位,所以要用一个16位寄存器来存放除数100

100001表为十六进制:186A1H

mov dx,1

mov ax,86A1H

mov bx,100

div bx

 

程序执行后,(ax)=03E8H(即1000),(dx)=1(余数为1)。

 

计算1001/100

被除数1001可用ax寄存器存放。除数100可用8位寄存器存放。即可进行8位的除法。

mov ax,1001

mov bl,100

div bl

程序执行后,(al)=0AH(即10),(ah)=1(余数为1)。

 

 

伪指令dd

db    定义字节型数据;define byte 一个字节表示8个位;

dw   定义字型数据;    define word 一个节表示两个字节;

dd    定义双字型数据;define dword(double word,双字)。两个字。四个字节。

 

 

data segment

       db 1

       dw 1

       dd 1

data ends

 

data段中定义了三个数据:

第一个数据为01H,在data:0处,占1个字节;

第二个数据为0001H,在data:1处,占1个字,两个字节;

第三个数据为00000001H,在data:3处,点2个字,四个字节。

 

 

dup

dup是一个操作符,在汇编语言中同dbdwdd等一样,也是由编译器识别处理的符号。它是和dbdwdd等数据定义伪指令配合使用的,用来进行数据的重复。如:

db 3 dup (0)

定义了3个字节,它们的值都是0,相当于 db 0,0,0

db 3 dup (0,1,2)

定义了9个字节,它们是012012012,相当于db 0,1,2, 0,1,2, 0,1,2

db 3 dup (‘abc’, ‘ABC’)

定义了18个字节,它们是’ abcABC abcABC abcABC’,相当于 db ‘abcABC abcABC abcABC’

 

dup的使用格式如下:

db 重复的次数 dup (重复的字节型数据)

dw 重复的次数 dup (重复的字型数据)

dd 重复的次数 dup (重复的双字数据)

 

dup是一个十分有用的操作符,比如我们要定义一个容量为200个字节的栈段。

stack segment

       db 200 dup (0)

stack ends

 

 

posted on 2010-08-04 10:29 luqingfei 阅读(519) 评论(0)  编辑 收藏 引用 所属分类: 汇编语言基础学习


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理


导航

<2010年9月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

统计

留言簿(6)

随笔分类(109)

随笔档案(105)

Blogers

Game

Life

NodeJs

Python

Useful Webs

大牛

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜