在代码段中使用数据:
dw 可以定义字型数据: dw 0123h , 0033h ,0ff4h , 0ac3h 这样就定义了4个字型数据,占8个字节。也可以这样定义数据,dw 0,0 ,0, 0, 0, 0, 0, 0 这样就定义了8个字型数据。dw 定义的都是字型数据。
那么当我们在源程序中写上了这样一行代码,运行程序时,我们的这些数据放在哪呢?
运行程序时,寄存器CS中存放我们代码段的段地址,而用dw定义的数据位于代码段的最开始,偏移地址从0开始。所以我们在源程序中编写的程序,就是那些汇编指令,在内存中储存时,要在这些数据的后面。所以我们运行程序时要把IP设为这些数据最后一个偏移地址后面一个地址。所以要设置IP的话,就要使用debug,这样很麻烦。有一种办法我们可以让程序入口直接指向我们的汇编程序的入口。用 start: 程序运行时会自动将start: 后面的代码作为程序入口。在最后结束时 end 也得改成end start。最后的 end start 不是说结束 start ,而是指明 查程序入口在 start 处。总之我们要让CPU从何处开始执行程序,只要让 “end 标号” 指明就可以了。
在代码段中使用栈:
可以使用 dw 来开辟一段内存空间,如 dw 0 ,0, 0, 0, 0, 0, 0, 0 这样程序在运行时,就有了一段8个字型,16个字节的内存空间。我们可以将这段内存当做栈来使用,使用时要将SS:IP 指向栈底。
将数据,代码,栈,放入不同的段中:
我们先编写一个汇编程序
我们可以看到上面我们用 assume 将几个寄存器与我们的几个不同的段联系起来了,这个为什么我们暂时还不用知道,反正每次都要将于我们段相关的寄存器联系起来,比如后面的 data 段是存放数据的,我们就将它与段寄存器DS联系起来,段stack是我们用来作为栈的,所以我们将它与段寄存器SS联系起来。段 code 是要执行的命令代码段,我们将它与段寄存器CS联系起来。
我们还可以看到,我们下面用了类似于这样的指令:mov ax,data mov ds,ax ,因为我们要将data段里面的东西作为数据储存,所以要将那个段的段地址存入段寄存器CS中,而在对这个文件编译后,段名代表的就是这个段的段地址,所以我们可以用上面那种操作。
然后我们用masm对其进行编译生成目标文件。
然后再用link连接,生成可执行文件。
我们用debug对其进行追踪。
我们可以从下面显示的第一个命令得知,段stack的段地址为076b所以我们使用d命令查看。
的确空出了16个字节。
然后我们继续执行才程序。
我们可以看到,执行改变寄存器SS中的值得命令,执行后,后面的命令也紧接着执行了。然后我们根据后面的命令可以得知段data的段地址。我们用命令 d 来查看。
可以看到 数据和我们写入的数据是一样的。
我们用 P 命令结束了循环。
再用 d 命令查看一下我们的栈中是否存放进了我们的数据。
可以看到数据已经存入我们所划分的栈中。