. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->第一个程序
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  讨论个程序运行时,段寄存器值设置的问题  [已解决] 回复[ 2次 ]   点击[ 414次 ]  
study_soft
[帖 主]   [ 发表时间:2008-03-13 13:23 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:18
注册日期:2008-02-20 10:20
在xp的command Prompt下运行汇编程序,随意的一个代码:
assume cs:codesg,ds:datasg 
    datasg segment 
    dd 123456h 
    dw 789h,0h 
    datasg ends 
    codesg segment 
    start: mov ax,datasg 
    mov ds,ax 
    mov ax,ds:[0] 
    mov dx,ds:[2] 
    div word ptr ds:[4] 
    mov ds:[6],ax 
    mov ax,4c00h 
    int 21h 
    codesg ends 
    end start 
用DEBUG运行,DS=15AC,ES=15AC,SS=15BC,CS=15BD,IP=0000,SP=0000...
用U命令可以看到:第一行指令是MOV AX,15BC
我用D 15AC:0000看到的是一些与程序无关的数据,
我用D 15BC:0000看到的是56 34 12 00 89 07 00 00,
用T命令执行第一行指令是MOV AX,15BC后,DS=15BC,ES=15AC,SS=15BC,CS=15BD,IP=0000,SP=0000...

我自己对程序运行情况的分析是:
1)给datasg设置15BC值是程序装入内存时系统分配的,对吗?
2)此时DS和SS值相等,IP=0000,SP=0000,我在代码里某处加了push ax的指令,执行后,发现SP=FFFE,是否意味着如果代码里没设置堆栈段而又使用堆栈,则椎栈会和数据段共用一段空间,只是方向不同,堆栈从64K空间的底部往上走,数据段从64K空间的顶部向下。

想请问我的想法对否?
wdm
[第1楼]   [ 回复时间:2008-03-13 21:00 ]   [引用]   [回复]   [ top ] 
荣誉值:342
信誉值:0
注册日期:2007-12-06 10:21
1)给datasg设置15BC值是程序装入内存时系统分配的,对吗? 
====================
当然是系统分配的。只不过,程序加载后ds指向的是你的程序的psp头,这个栈256个字节,所以,你第一个数据段会比你程序刚加载时候的ds的段地址多10H

2)此时DS和SS值相等,IP=0000,SP=0000,我在代码里某处加了push ax的指令,执行后,发现SP=FFFE,是否意味着如果代码里没设置堆栈段而又使用堆栈,则椎栈会和数据段共用一段空间,只是方向不同,堆栈从64K空间的底部往上走,数据段从64K空间的顶部向下。
=======================
确实是这样。我想默认的ss值是你程序的第一个段的值。如果你第一个段是代码段,我想应该就是共享代码段了吧。
如果,这样的话,我也有一个疑问。当你的第一个段是代码段,而且你的代码段够了64K了,你没有指定栈段,如果栈段还是默认的使用第一个段的空间的话,当你程序中使用了push指令后,就会将代码的后面数据给覆盖,造成你的程序出错。是不是这样呢?楼主有兴趣可以试试看。
呵呵
study_soft
[第2楼]   [ 回复时间:2008-03-19 10:00 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:18
注册日期:2008-02-20 10:20
此贴由 贴主 于 [ 2008-03-19 10:00 ] 结贴。 结贴原因:问题已解决
得分情况: 1楼(wdm):2分  
此问题已结贴!
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved