8086汇编学习笔记3-程序组织

1. 关于段地址和偏移地址

8086CPU有20位地址总线,达到1MB寻址能力,但是8086CPU又是16位结构CPU,一个寄存器只能存16位数据。所以8086用两个寄存器来表示一个20位的物理地址,一个称为段地址,一个称为偏移地址,然后由地址加法器将两个16位地址合成一个20位的物理地址。地址加法器计算物理地址公式:

物理地址=段地址*16+偏移地址

2. CS寄存器用来存放代码段段地址,IP为指令指针寄存器,任意时刻,8086CPU将CS:IP指向的内容当作指令来执行。读取一条指令后,IP中的值自动增加。

不能用mov指令来修改CS、IP寄存器的值,能够改变CS、IP值的指令统称为转移指令。

编程时,可以根据需要,将一段地址连续,起始地址为16倍数内存单元用来存放代码,这段内存空间称为代码段。

3. DS寄存器,用来存放要访问数据段的段地址。

在编程时,可根据需要,将一段地址连续、起始地址为16的倍数的内存单元用来存放数据,这段内存空间可以称为数据段。

4. 栈顶段地址存放在寄存器SS中,偏移地址存放在SP中,即任意时刻,SS:SP指向栈顶元素。

在编程时,可根据需要,将一段地址连续、起始地址为16的倍数的内存单元当作栈空间来用,这段内存空间可以称为栈。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的8086汇编程序,用于判断10-300内的整数是否素数: ``` .MODEL SMALL .STACK 100H .DATA MSG1 DB 'Number is prime$' MSG2 DB 'Number is not prime$' .CODE MAIN PROC FAR MOV AX, @DATA MOV DS, AX MOV CX, 10 ; 初始化计数器为10 LOOP1: CMP CX, 300 ; 如果计数器大于300,跳出循环 JG EXIT MOV BX, 2 ; 初始化除数为2 LOOP2: MOV AX, CX ; 将CX的值赋给AX XOR DX, DX ; 将DX清零 DIV BX ; 将AX除以BX,商在AL中,余数在AH中 CMP AH, 0 ; 如果余数为0,说明CX可以被BX整除,不是素数 JE NOT_PRIME INC BX ; 将除数加1 CMP BX, CX ; 如果除数大于CX,说明CX是素数 JG IS_PRIME JMP LOOP2 ; 继续尝试下一个除数 IS_PRIME: MOV AH, 9 LEA DX, MSG1 INT 21H ; 输出“Number is prime” JMP CONTINUE NOT_PRIME: INC CX ; 将计数器加1 JMP LOOP1 ; 继续尝试下一个数字 CONTINUE: INC CX ; 将计数器加1 JMP LOOP1 ; 继续尝试下一个数字 EXIT: MOV AX, 4C00H INT 21H ; 程序结束 MAIN ENDP END MAIN ``` 该程序的实现思路是,从10开始逐个判断300以内的整数是否为素数。对于每个数字,我们从2开始逐个尝试除数,如果能够整除,则说明该数字不是素数,否则继续尝试下一个除数。如果所有除数都不能整除该数字,则说明该数字是素数。 在程序中,我们使用CX寄存器来作为计数器,从10开始逐个尝试数字。对于每个数字,我们使用BX寄存器来作为除数,从2开始逐个尝试。使用DIV指令进行除法运算,如果余数为0,则说明该数字能够被除数整除,不是素数;否则继续尝试下一个除数。如果所有除数都不能整除该数字,则说明该数字是素数,输出相应信息。最后,继续尝试下一个数字,直到计数器值大于300,程序结束。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值