汇编语言——多个段的程序(基于8086CPU)

本文介绍了汇编语言中如何在代码段使用dw和db命令定义数据,并通过start标志设定程序入口。同时,讲解了如何在代码段中创建栈,以及如何为栈分配内存空间。此外,还讨论了如何将数据、代码和栈分别放入不同的段,以及assume伪指令的作用。最后,提到了段地址和段寄存器寻址的原理。
摘要由CSDN通过智能技术生成

1. 在代码段中使用数据

dw命令

  • 定义字型数据。
  • dw == define word
  • 例如:
    在这里插入图片描述
    这样dw 0123H, 0456H会把数据存在cs段的最开始,因为dw是代码段的第一行

db命令

  • 类似dw,但是是定义字节型数据。

start标志代表cpu从哪里开始读取指令

在这里插入图片描述

  • 例如上图,这样cpu就不会从dw开始读取,而是从mov bx, 0开始读取
  • 因为一开始的dw是设置字型内存,从dw下边开始才是代码执行,所以要加上start
  • 所以end出来通知编译器结束,还能通知编译器程序入口位置。

2.在代码段中使用栈

  • 通过dw定义申请到内存空间,然后将这一段内存空间当栈使用
  • 在这里插入图片描述
  • 这里申请了八个字空间,把栈的段地址和偏移地址赋值,相当于把那段内存空间当栈使用

3.将数据、代码、栈放入不同的段

在这里插入图片描述

  • stack是一个地址,但是不会在一开始就和ds绑定,需要mov ax,stack mov ss,ax这样
  • 由于assum是伪指令,
    所以cpu是看不懂的,所以cs:code,ds:data只是绑定,但是cpu不会设置。
  • CPU会把end start的start的标号指向的那条指向入口,设置CS:IP
  • assume只是对编译器编译程序起作用,并不能对段寄存器进行实际的赋值。assume的目的是为了在编译时确定变量的段地址。
  • 因为段总是16的倍数,所以如果段中的数据占N字节,程序加载后,实际占的空间是16*(N/16+1)注意这里的是向下取整,地板除。
  • 编译器在编译的时候是从上往下的,所以程序段相对位置不同,段地址也不同,而且每一段程序段占的空间一定是16的倍数,这个和段寄存器寻址的原理有关。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值