zoukankan      html  css  js  c++  java
  • [汇编语言]-第八章 div指令,伪指令dd,dup

    1- div除法指令

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

    (2) 被除数: 默认放在AX和DX或AX中

      除数为8位, 被除数为16位, 默认在AX中存放.

      除数为16位, 被除数为32位, 在DX或AX中存放. AX存放低16位,DX存放高16位.

    (3) 结果

      除数为8位, 则AL存储除法操作的商, AH存放余数

      除数为16为, 则AX存储除法操作的商, DX存放余数

    2- 格式如下

      div reg

      div 内存单元

      div byte ptr ds:[0]

      含义为:(al) = (ax)/((ds)*16+0)的商

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

      div word ptr es:[0]

      含义为:(ax) = [(dx)*10000H+(ax)]/((es)*16+0)的商  

          (dx) = [(dx)*10000H+(ax)]/((es)*16+0)的余数

      div byte ptr [bx + si + 8]

      含义为:(al) = (ax)/((ds)*16+(bx)+(si)+8)的商

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

    编程:利用除法指令计算 100001/100 (16位除法)

    分析:100001大于65535,所以只能用dx和ax两个寄存器联合存放100001,也就是要进行16位除法,除数100小于255,可以在一个8位寄存器中存放,但是因为被除数是32位的,除数必须是16位,所以用16位的寄存器来存放除数100.

    因为要分别为dx和ax赋100001的高16位和低16位,所以应先将100001表示为16进制形式.186A1H.

    100表示为16进制形式64H,用bx存储

    (ax) = [(dx)*10000H+(ax)]/(bx)的商 03E8H

    (dx) = [(dx)*10000H+(ax)]/(bx)的余数 0001H

    编程:利用除法指令计算1001/100(8位的除法)

    被除数可以用ax存放,除数可以用8位寄存器bl

    (al)=0AH

    (dx)=1H

    3- 伪指令 dd

      db 字节型数据

      dw 字型数据

      dd dword (double word)双字型数据

      data segment

        db 1    ;为01H 在data:0处, 占1个字节

        dw 1    ;为0001H 在data:1处, 占1个字

        dd 1    ;为00000001H 在data:3处, 占2个字

      data ends

     1 ;用div计算data段中第一个数据除以第二个数据后,商存放到第三个数据的存储单元中.
     2 ;余数存储到第四个存储单元中.
     3 assume cs:codesg,ds:datasg
     4 datasg segment            ;储存 0B60:0 F A1 86 01 00 64 00 00 00 00 00
     5     dd 100001
     6     dw 100
     7     dw 0
     8     dw 0
     9 datasg ends
    10 codesg segment
    11 start:  mov ax,datasg
    12         mov ds,ax
    13         mov ax,ds:[0]                ;ax存储低16位
    14         mov dx,ds:[2]                ;dx存储高16位
    15         div  word  ptr  ds:[4]       ;计算除法
    16         mov ds:[6],ax                ;商存储第3个单元
    17         mov ds:[8],dx                ;余数存储第4个单元
    18     
    19         mov ax,4c00h
    20         int 21h
    21 codesg ends
    22 end start

    4- dup 用来进行数据重复的

      db 3 dup (0) ;定义了3个字节,相当于db 0,0,0

      db 3 dup (0,1,2) ;定义了9个字节,相当于db 0,1,2,0,1,2,0,1,2

      db 3 dup ('abc','ABC') 定义了18个字节, 相当于 db 'abcABCabcABCabcABC'

      可见dup的使用格式如下:

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

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

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

      定义一个容量为200个字节的栈段

      stack segment

        dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

        dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

        dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

        dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

        dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

      stack ends

      stack segment

        dw 200 dup (0)

      stack ends

      

  • 相关阅读:
    Python Django 零基础破门而入篇(五)
    Python Django 零基础破门而入篇(四)
    Python Django 零基础破门而入篇(三)
    Python Django 零基础破门而入篇(二)
    Python Django 零基础破门而入篇(一)
    ACM/ICPC 之 计算几何入门-叉积-to left test(POJ2318-POJ2398)
    ACM/ICPC 之 机器调度-匈牙利算法解最小点覆盖集(DFS)(POJ1325)
    ACM/ICPC 之 卡卡的矩阵旅行-最小费用最大流(可做模板)(POJ3422)
    ACM/ICPC 之 伞兵-最小割转最大流(POJ3308)
    ACM/ICPC 之 最小割转网络流(POJ3469)
  • 原文地址:https://www.cnblogs.com/galoishelley/p/3571759.html
Copyright © 2011-2022 走看看