• 实验五 编写、调试具有多个段的程序


    1)将下面的程序编译、连接,用Debug加载、跟踪,然后回答问题。

    ①可以发现,data段的数据在执行程序后,程序返回前并未改变,仍是原始数据。

    ②从图中可以看出,CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A。

    ③进一步可以发现,若code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。

    2)将下面的程序编译、链接,用debug加载、跟踪,然后回答问题。

     

     

    ①与(1)的结果一样,data段的数据在执行程序后,程序返回前仍未改变,仍是原始数据。

    ②从图中可以看出,CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A。

    ③与(1)的结果一致,若code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。

    ④对比(1)(2)可以发现,(1)中data段数据有16个字节,占用了16个字节空间,而(2)中data段数据只有4个字节,但实际上(2)也占用了16字节的空间,其中不足的部分都用0补全了。所以推测,若段中数据为N个字节,则该段实际占用的空间为  ([N/16]+1)*16 个字节([]为取整符号)。

     3)将下面的程序编译、链接,用debug加载、跟踪,然后回答问题。

    ①可以发现,data段的数据在执行程序后,程序返回前并未改变,仍是原始数据。

    ②从图中可以看出,CPU执行程序,程序返回前,CS=076A,SS=076E,DS=076D。

    ③进一步可以发现,若code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。

    4)如果将(1)(2)(3)题中的最后一条伪指令“end start”改为“end”(也就是说,不指明程序的入口),则哪个程序仍然可以正确执行?请说明原因。

     答:如果将最后一条伪指令“end start”改为“end”,相当于没有指明程序入口,此时程序就会从加载进内存的第一个单元起开始执行。在(1)(2)题中,都是数据先加载进内存,CPU会误把数据也当成指令执行,最终不能保证被正确执行;而(3)题则是代码段先被加载进内存,因而可以被正确执行。

    5)程序如下,编写code段中的代码,将a段和b段中的数据依次相加,将结果存到c段中。

     

    6)程序如下,编写code段中的代码,用push指令将a段中的前8个字符型数据,逆序存储到b段中。

     

  • 相关阅读:
    WOJ 1055
    做人做事
    实现Runnable接口和扩展Thread使用场景
    利用Perf4j 对java项目进行性能监控
    android画笔错位问题的解决
    IE常见的CSS的BUG(二)
    激动啊,终于诞生了,编译了属于俺自己的 JDK
    图像处理特征不变算子系列之Moravec算子(一)
    对象的动态建立和释放
    用TinyXml2读取XML文件的一个简单Demo
  • 原文地址:https://www.cnblogs.com/wangchuan-LC/p/10016402.html
Copyright © 2020-2023  润新知