zoukankan      html  css  js  c++  java
  • 汇编语言3

    8086CPU的指令,可以处理两种尺寸的数据,byte和word。所以在机器指令中要指明,指令进行的是字操作还是字节操作。对于这个问题,汇编语言中用一下方法处理。

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

    例如:

    下面的指令中,寄存器指明了指令进行的是字操作:

    mov ax,1

    mov bx,ds:[0]

    mov ds,ax

    mov ds:[0],ax

    inc ax

    add ax,1000

    下面的指令中,寄存器指明了指令进行的是字节操作:

    mov al,1

    mov al,bl

    mov al,ds:[0]

    mov ds:[0],al

    inc al

    add al,100

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

    例如:

    下面的指令中,用word ptr 指明了指令访问的内存单元是一个字单元:

    mov word ptr ds:[0],1

    inc word ptr [bx]

    inc word ptr ds:[0]

    add word ptr [bx],2

    下面的指令中,用byte ptr 指明了指令访问的内存单元是一个字单元:

    mov byte ptr ds:[0],1

    inc byte ptr [bx]

    inc byte ptr ds:[0]

    add byte ptr [bx],2

    在没有寄存器参与的内存单元访问指令中,用word prt 或byte ptr 显性地指明所要访问的内存单元的长度是很必要的。否则,CPU无法得知所要访问的单元,还是字节单元。

    假如我们用Debug查看内存的结果如下:

    2000:1000 FF FF FF FF FF FF ......

    那么指令:

    mov ax,2000H

    mov ds,ax

    mov byte ptr [1000H],1

    将使内存中的内容变为:

    2000: 1000 01 FF FF FF FF FF ......

    而指令:

    mov ax,2000H

    mov ds,ax

    mov word ptr [1000H],1

    将使内存中的内容变为:

    2000:1000 01 00 FF FF FF FF ......

      这是因为 mov byte ptr [1000H],1访问的是地址为 ds:1000H 的字节单元,修改的是ds:1000H 单元的内容;而mov word ptr [1000H],1 访问的是地址为 ds:1000H 的字单元,修改的是 ds:1000H 和 ds:1001H 两个单元的内容。

    PTR用来指出操作数的类型或尺寸,通常用在跳转/调子程序或寻址。寻址时用来指明是BYTE、WORD还是DWORD,跳转时则是FAR或NEAR。

    (3) 其他方法

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

     

     

    分析一下指令执行过程:

    (1): mov ax,6622h 

    (2): jmp 1000:3  

    (3):mov ax,0000

    (4):mov bx,ax

    (5):jmp bx

    (6):mov ax,0123h

    (7):怎么执行?

                                 //初始:  CS:IP为2000:0,   2000:0的内存   00 00 00 00 00 00 00 00 00 00 00 00 00
    (1): mov ax,6622h  //执行后:CS:IP为2000:3   2000:0的内存   B8 22 66 00 00 00 00 00 00 00 00 00 00         
    (2): jmp 1000:3    //载入后:CS:IP为2000:8    2000:0的内存   B8 22 66 EA 03 00 00 10 00 00 00 00 00
                               //执行后:CS:IP为1000:3

                               //初始:                           1000:0的内存   00 00 00 00 00 00 00 00 00 00 00 00 00
    (3):mov ax,0000  //执行后:CS:IP为1000:6    2000:0的内存   00 00 00 B8 00 00 00 00 00 00 00 00 00
    (4):mov bx,ax    //执行后:CS:IP为1000:8    2000:0的内存   00 00 00 B8 00 00 8B D8 00 00 00 00 00
    (5):jmp bx         //载入后:CS:IP为1000:10   2000:0的内存   00 00 00 B8 00 00 8B D8 FF E3 00 00 00

             //执行后CS:IP为1000:0

    (6):mov ax,0123h //执行后:CS:IP为1000:3    2000:0的内存   B8 23 31 B8 00 00 00 00 00 00 00 00 00

    (7):怎么执行?        //(6)执行后 会到(3)出执行,这是一个死循环

    1.汇编语言源程序中有两种指令,一种 汇编指令,一种伪指令。
    2.汇编指令有对应的机器指令,最终为CPU所执行
    3.伪指令没有对应的机器指令,由编译器执行的
    4.assume,segment,ends,end均伪指令


    第一步:编写汇编源代码

    新建文本 1.txt

    代码如下:

    assume cs:codesg  ;将cs寄存器和codesg代码段关联

    codesg segment  ;codesg代码段开始

    mov ax,0123H
    mov bx,0456H
    add ax,bx
    add ax,ax

    mov ax,4c00H
    int 21      ;mov ax,4c00  int 21 这2条指令实现程序返回

    codesg ends  ;codesg代码段结束 segment,ends成对使用

    end          ;整个汇编程序结束


    第二步:对源代码进行编译连接

    下载 masm5 编译工具, 放在c盘根目录 

    第三步:得到最终 exe

  • 相关阅读:
    技术周刊 · 耿耿星河欲曙天 | SpaceX 上的前端架构;跨平台新选择;开源世界的新“大门”;用户推荐算法的敲门砖……
    说说SVG的feTurbulence滤镜
    机器学习进阶
    小程序与动画的故事
    技术周刊 · 迢迢山径峻 | Web 开发成长图谱;下一代前端构建技术;AI 应用下支离破碎的真实;不懂产品不会开发;虚拟货币是新时代的黄金
    从中断机制看 React Fiber 技术
    三分钟了解数字人民币
    凹凸技术揭秘:如何服务 toG 项目——数字人民币项目前端总结
    使用 Phaser3+Matter.js 实现“合成大西瓜”游戏
    痞子衡嵌入式:快速定位i.MXRT600板级设计ISP[2:0]启动模式引脚上电时序问题的方法
  • 原文地址:https://www.cnblogs.com/mayingkun/p/4238420.html
Copyright © 2011-2022 走看看