鱼C论坛

 找回密码
 立即注册
查看: 292|回复: 3

[已解决]求助 汇编教程第19节课3段都是同一范围的问题!!!!!

[复制链接]
发表于 2024-11-1 18:49:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
跪求问一下 汇编教程第19节课 代码段范围10000-1001f这个范围 代码段和栈段和数据段的范围都是一样的 然后执行到mov bx,[4]的时候 [4]变成了[c804] 后面的程序也执行不下去了 为什么 真的想不通

还有我是新人  不知道为啥发布了图片  只能文字描述
视频内容是这样的
我们将10000H-1001FH安排为代码段,在里面存储以下代码
mov ax,1000H
mov ss,ax
mov sp,0020H
mov ax,cs
mov ds,ax
mov ax,[0]
add ax,[2]
mov bx,[4]
add bx,[6]
push ax
push bx
pop ax
pop bx
最佳答案
2024-11-1 22:51:23
本帖最后由 jackz007 于 2024-11-2 16:56 编辑

        关于堆栈,楼主应该明白以下两个概念:

1、堆栈属于公共数据区域,不止我们自己要使用,操作系统、调试器等都要使用,这些使用并非发生在我们知晓的情况下,就是说,堆栈一定会被 "秘密" 使用,这很正常;

2、由于堆栈指针是向下走的,只要堆栈被使用,就会破坏当前 SP 以下的数据,所以,当前 SP 以下的堆栈区域并不安全,而且,越接近 SP,危险性就会越大;

        在本例中,堆栈、数据、代码同段,共同使用了 1000:0000 - 1000:0020 总共只有 32 字节的存储空间,这就意味着凡是对这一区域的数据写入都有可能对指令数据造成破坏。在所有可能的破坏因素中,由于堆栈的深度过浅,导致机器指令的尾部位于 SP 以下,非常接近 SP 的部位,处于非常危险的状态。在使用 debug.exe 调试程序的过程中,指令数据的尾部遭到非预期地修改,而且,可以断定的是,这件事就发生在修改完堆栈段和栈顶指针的一瞬间。

        可以用本例做个实验,在 debug.exe 中输入全部代码后,用命令
F 1000:0020 L20 FF
        把地址 1000:0020 - 1000:003F 长度为 20H 的内存区域全部填充字节 FFH,然后,把这条指令
        mov sp,0020H
        改为:
        mov sp,0040H
        从头开始用 p 指令单步跟踪程序,每运行一步,就用指令
D 1000:0020 L20
        监视堆栈区域的变化,看看究竟执行到哪一步的时候,堆栈中的数据出现了非预期的改变(原始的 FF 被改变),并可以根据 SP 的值大致确定这个区域的深度到底有多少个字节。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-11-1 18:49:44 | 显示全部楼层
在汇编语言中,代码段、数据段和栈段的范围重叠可能会导致程序执行出现问题。根据你描述的情况,以下是可能的原因和解决方案:

1. **段重叠问题**:如果代码段、数据段和栈段的范围都设置为相同的10000H-1001FH,这会导致段重叠。段重叠会导致数据被代码覆盖,或者栈操作影响代码执行。

2. **寄存器设置错误**:在设置段寄存器时,确保每个段寄存器(如CS、DS、SS)指向正确的段地址。你的代码中,`mov ax,cs` 和 `mov ds,ax` 是正确的做法,但要确保 `mov ss,ax` 和 `mov sp,0020H` 设置的栈段和栈指针不会与代码段冲突。

3. **栈指针溢出**:`mov sp,0020H` 设置栈指针为20H,确保栈操作不会超出栈段的范围。如果栈段和代码段重叠,栈操作可能会覆盖代码。

4. **调试建议**:可以通过单步调试来查看每条指令执行后的寄存器和内存状态,找出问题所在。

建议你重新规划段的范围,确保它们不重叠。例如,将代码段、数据段和栈段分配到不同的内存区域。这样可以避免段重叠带来的问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-11-1 22:51:23 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2024-11-2 16:56 编辑

        关于堆栈,楼主应该明白以下两个概念:

1、堆栈属于公共数据区域,不止我们自己要使用,操作系统、调试器等都要使用,这些使用并非发生在我们知晓的情况下,就是说,堆栈一定会被 "秘密" 使用,这很正常;

2、由于堆栈指针是向下走的,只要堆栈被使用,就会破坏当前 SP 以下的数据,所以,当前 SP 以下的堆栈区域并不安全,而且,越接近 SP,危险性就会越大;

        在本例中,堆栈、数据、代码同段,共同使用了 1000:0000 - 1000:0020 总共只有 32 字节的存储空间,这就意味着凡是对这一区域的数据写入都有可能对指令数据造成破坏。在所有可能的破坏因素中,由于堆栈的深度过浅,导致机器指令的尾部位于 SP 以下,非常接近 SP 的部位,处于非常危险的状态。在使用 debug.exe 调试程序的过程中,指令数据的尾部遭到非预期地修改,而且,可以断定的是,这件事就发生在修改完堆栈段和栈顶指针的一瞬间。

        可以用本例做个实验,在 debug.exe 中输入全部代码后,用命令
F 1000:0020 L20 FF
        把地址 1000:0020 - 1000:003F 长度为 20H 的内存区域全部填充字节 FFH,然后,把这条指令
        mov sp,0020H
        改为:
        mov sp,0040H
        从头开始用 p 指令单步跟踪程序,每运行一步,就用指令
D 1000:0020 L20
        监视堆栈区域的变化,看看究竟执行到哪一步的时候,堆栈中的数据出现了非预期的改变(原始的 FF 被改变),并可以根据 SP 的值大致确定这个区域的深度到底有多少个字节。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-11-6 09:42:29 | 显示全部楼层
太牛逼了  一下子就懂了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-22 22:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表