zoukankan      html  css  js  c++  java
  • 王爽《汇编语言》第三版 第六章 包含多个段的程序

    6.1 在代码段中使用数据

      

      “dw”的含义是定义字型数据。dw即define word。

      由于它们在代码段中,程序在运行的时候CS中存放代码段的段地址,所以我们可以从CS中得到它们的段地址。

      因为用dw定义的数据处于代码段的最开始,所以偏移地址为0,这8 个数据就在代码段的偏移0、2、4、6、8、A、C、E处。

      end 除了通知编译器程序结束外,还可以通知编译器程序的入口在什么地方。

      
    6.2 在代码段中使用栈


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

      我们用和定义代码段一样的方法来定义多个段,然后在这些段里面定义需要的数据,或通过定义数据来取得栈空间。

      我们要将它送入bx中,就要用如下的代码:
        mov ax,data
        mov ds,ax
        mov bx,ds:[6]
      我们不能用下面的指令:
        mov ds,data
        mov ax,ds:[6]

      程序中对段名的引用,如指令“mov ds,data”中的“data”,将被编译器处理为一个表示段地址的数值。

      “代码段”、“数据段”、“栈段”完全是我们的安排。

      “assume cs:code,ds:data,ss:stack”将cs、ds和ss分别和code、data、stack段相连。

      CPU到底如何处理我们定义的段中的内容,是当作指令执行,当作数据访问,还是当作栈空间,完全是靠程序中具体的汇编指令,和汇编指令对CS:IP、SS:SP、DS等寄存器的设置来决定的。

    参考资料:《小甲鱼汇编零基础入门》

     

         《汇编语言》第三版

  • 相关阅读:
    畅通工程续 (dijkstra)
    最短路径问题 HDU 3790
    【基础算法-模拟-例题-玩具谜题】-C++
    【基础算法-模拟-例题-金币】-C++
    【动态规划例题-数塔问题】-C++
    【基本数据结构之'图'】
    【最小生成树之Kruskal例题-建设电力系统】-C++
    【最短路算法例题-升降梯上】-C++
    【基本数据结构之栈】
    【栈-例题】网页跳转-C++
  • 原文地址:https://www.cnblogs.com/mubu/p/6359904.html
Copyright © 2011-2022 走看看