前言
在之前我们写的程序中,所有代码都是在一块的,之前在读程序时我们要考虑每一个地址内容是什么,非常的杂乱,在本章中可以通过每一个不同的段来存放不同的数据,这样就大大提高了代码的规范和完整性。
6.1 在代码段中使用数据
如果有这么一个需求,要求存入数据,但是没有指定在哪个数据单元中,我们应该怎么做呢?
我们可以通过dw关键字
,来直接将其存放在目标指定代码段中,像下面这个程序一样就是在cs代码段中定义数据,按顺序存入数据。
但是上面存入数据后我们看一下在cs段的内容,发现上面有一段我们根本没有写过的代码。
这段代码就是我们写入的dw数据,因为我们把cs段中放入了数据,而cs是代码段,也就是说程序把数据当成了代码执行,这也就是我们上面说到过得问题。
我们如果要解决的话应该将数据和代码段分开,通过定义```标号``也就是下图的start,让程序知道代码从这开始,数据在他上面定义。而标号也有更重要的作用,详解见下文。
这回再看,发现程序没有问题了。
6.2 在代码段中使用栈
在代码中使用栈有三个步骤
,
- 先定义栈段从什么位置开始什么位置结束
- 再初始化栈段到栈顶位置设置SS:SP确定栈顶的位置
- 最后在代码段中使用出入栈的操作结束
在下面的程序中,实现栈的逆序存放,利用loop循环配合PUSH和POP操作实现整个栈的出入。
因为要定义栈空间,所以在定义数据时,要多定义些0数据空间,来供栈段存储。
在底下的数据段和栈段中通过通过PUSH让数据循环入栈,再POP循环出站保存在CS:[BX]中,根据这双重栈的特性就实现了逆序存放程序的操作。
6.3 将代码、数据、栈放入不同段
标号的作用
上面数据段和栈段还是有之前的问题,显的非常混乱,时刻要注意哪里是数据哪里是栈,这样我们可以通过之前提到的标号
来解决这个问题。
在下面的程序中assume cs:code,ds:data,ss:stack将不同的地方定义不同的段,分开实行,这样就不会造成数据杂乱的问题。
在程序中我们不用刻意初始化代码段的开始,因为程序默认会执行代码段。
所以我们只需要初始化栈段和数据段
即可。
通过stack,code,code三个不同的标号来划分了不同的段,这让程序更加的井然有序。