cx中存放的是不包括256字节psp后程序大小,ds中存放的是psp头的地址

来源:互联网 发布:剑三正太捏脸数据妖孽 编辑:程序博客网 时间:2024/05/27 10:44

RT:是我在调试一个masm程序(王爽ch8实验7)时发现的规律


codesg 1404:0 007c 共007dh Byte
data 4*21+4*21+2*21=210=D2h  因数据段大小必须为16的整数倍所以实际榨油空间为E0h
table 16*21=150h 正好为16的整数倍

e0h+d2h+150h=2adh    正好为程序刚加载进内存是cx=2adh 为程序额大小(psp的256byt=100h Byte 不计算在内)

刚加载时的ds中的数据为psp 的开头位置的段地址,偏移地址为0
DS=13D1
(ds*16+0)+256+(cx)= 140bdh=1404:007d 此地址为程序最后一个字节的下一个字节的地址

以上结论验证成功

==== 以下是debug信息====
D:\asm\masm500>debug C8S7.EXE
-r
AX=0000  BX=0000  CX=02AD  DX=0000  SP=0000  BP=0000  SI=0000  DI=0000
DS=13D1  ES=13D1  SS=13E1  CS=1404  IP=0000   NV UP EI PL NZ NA PO NC
1404:0000 B8EF13        MOV     AX,13EF


-u
1404:0000 B8EF13        MOV     AX,13EF
1404:0003 8ED8          MOV     DS,AX
1404:0005 B8E113        MOV     AX,13E1
1404:0008 8EC0          MOV     ES,AX
1404:000A BB0000        MOV     BX,0000
1404:000D BE0000        MOV     SI,0000
1404:0010 B91500        MOV     CX,0015
1404:0013 26            ES:
1404:0014 8B04          MOV     AX,[SI]
1404:0016 8907          MOV     [BX],AX
1404:0018 83C602        ADD     SI,+02
1404:001B 26            ES:
1404:001C 8B04          MOV     AX,[SI]
1404:001E 894702        MOV     [BX+02],AX
-u
1404:0021 83C602        ADD     SI,+02
1404:0024 83C310        ADD     BX,+10
1404:0027 E2EA          LOOP    0013
1404:0029 BB0000        MOV     BX,0000
1404:002C BE0000        MOV     SI,0000
1404:002F B91500        MOV     CX,0015
1404:0032 26            ES:
1404:0033 8B4454        MOV     AX,[SI+54]
1404:0036 26            ES:
1404:0037 8B5C56        MOV     BX,[SI+56]
1404:003A 894705        MOV     [BX+05],AX
1404:003D 895F07        MOV     [BX+07],BX
1404:0040 83C604        ADD     SI,+04
-u
1404:0043 83C310        ADD     BX,+10
1404:0046 E2EA          LOOP    0032
1404:0048 BB0000        MOV     BX,0000
1404:004B BE0000        MOV     SI,0000
1404:004E B91500        MOV     CX,0015
1404:0051 26            ES:
1404:0052 8B84A800      MOV     AX,[SI+00A8]
1404:0056 89470A        MOV     [BX+0A],AX
1404:0059 83C602        ADD     SI,+02
1404:005C 83C310        ADD     BX,+10
1404:005F E2F0          LOOP    0051
1404:0061 BB0000        MOV     BX,0000
-u
1404:0064 B91500        MOV     CX,0015
1404:0067 8B4705        MOV     AX,[BX+05]
1404:006A 8B5707        MOV     DX,[BX+07]
1404:006D F7770A        DIV     WORD PTR [BX+0A]
1404:0070 89470D        MOV     [BX+0D],AX
1404:0073 83C310        ADD     BX,+10
1404:0076 E2EF          LOOP    0067
1404:0078 B8004C        MOV     AX,4C00
1404:007B CD21          INT     21
==========debug信息//


=====一下是调试时用的源代码

assume cs:codesg

data segment
    db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
    db '1984','1985','1986','1987','1988','1989','1990','1991','1992'
    db '1993','1994','1995'
    ;以上是21年的21个字符串
    dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
    dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
    ;以上是表示21年公司总收入的21个dword型数据
    dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
    dw 11542,14430,15257,17800
    ;以上是表示21年公司雇员人数的21个word型数据
data ends

table segment
    db 21 dup ('year summ ne ?? ')
table ends

codesg segment
start:    mov ax,table
    mov ds,ax

    mov ax,data
    mov es,ax

    mov bx,0    ;指示table中的第几条记录
    mov si,0    ;指示data中年份数组中的字
    mov cx,21
s1:    ;mov word ptr [bx].0,es:[si]
    mov ax,es:[si]
    mov [bx].0,ax
    add si,2    ;指示下一个字的数据
    mov word ptr [bx].2,es:[di]
    add si,2    ;指示下一个字的数据
    
    add bx,16    ;指示下一条记录
    loop s1;
;以上循环向table的各条记录总填充年份字符串(4Byte)

    mov bx,0
    mov si,0
    mov cx,21
s2:    mov word ptr [bx].5,es:84[si]
    add si,2
    mov word ptr [bx].7,es:84[si]
    add si,2

    add bx,16
    loop s2
;以上循环想table的各条记录中填写收入数(dd型)

    mov bx,0
    mov si,0
    mov cx,21
s3:    mov word ptr [bx].0ah,es:168[si]
    add si,2

    add bx,16
    loop s3
;以上循环想table的各条记录中填写雇员数(dw型)

    mov bx,0
    mov cx,21
s4:    mov ax,[bx].5
    mov dx,[bx].7

    div word ptr [bx].0ah

    mov [bx].0dh,ax

    add bx,16
    loop s4

    mov ax,4c00h
    int 21h

codesg ends

end start

========以上是源码




===以下是 查看程序运行后table中的数据情况==
data 13e1:0 df
table 13ef:0 14f

code cs:0 007c


程序退出前table内容:
-d ds:0 14f
13EF:0000  31 39 37 35 20 10 00 00-00 20 03 00 20 05 00 20   1975 .... .. ..
13EF:0010  31 39 37 36 20 16 00 00-00 20 07 00 20 03 00 20   1976 .... .. ..
13EF:0020  31 39 37 37 20 7E 01 00-00 20 09 00 20 2A 00 20   1977 ~... .. *.
13EF:0030  31 39 37 38 20 4C 05 00-00 20 0D 00 20 68 00 20   1978 L... .. h.
13EF:0040  31 39 37 39 20 56 09 00-00 20 1C 00 20 55 00 20   1979 V... .. U.
13EF:0050  31 39 38 30 20 40 1F 00-00 20 26 00 20 D2 00 20   1980 @... &. ..
13EF:0060  31 39 38 31 20 80 3E 00-00 20 82 00 20 7B 00 20   1981 .>.. .. {.
13EF:0070  31 39 38 32 20 A6 5F 00-00 20 DC 00 20 6F 00 20   1982 ._.. .. o.
13EF:0080  31 39 38 33 20 91 C3 00-00 20 DC 01 20 69 00 20   1983 .... .. i.
13EF:0090  31 39 38 34 20 C7 7C 01-00 20 0A 03 20 7D 00 20   1984 .|.. .. }.
13EF:00A0  31 39 38 35 20 81 24 02-00 20 E9 03 20 8C 00 20   1985 .$.. .. ..
13EF:00B0  31 39 38 36 20 8A 03 03-00 20 A2 05 20 88 00 20   1986 .... .. ..
13EF:00C0  31 39 38 37 20 7C 47 05-00 20 D2 08 20 99 00 20   1987 |G.. .. ..
13EF:00D0  31 39 38 38 20 EB 03 09-00 20 E9 0A 20 D3 00 20   1988 .... .. ..
13EF:00E0  31 39 38 39 20 CA 42 0C-00 20 C5 0F 20 C7 00 20   1989 .B.. .. ..
13EF:00F0  31 39 39 30 20 18 0D 12-00 20 03 16 20 D1 00 20   1990 .... .. ..
13EF:0100  31 39 39 31 20 38 1F 1C-00 20 22 20 20 E0 00 20   1991 8... "  ..
13EF:0110  31 39 39 32 20 58 19 2A-00 20 16 2D 20 EF 00 20   1992 X.*. .- ..
13EF:0120  31 39 39 33 20 28 44 39-00 20 5E 38 20 04 01 20   1993 (D9. ^8 ..
13EF:0130  31 39 39 34 20 28 F0 46-00 20 99 3B 20 30 01 20   1994 (.F. .; 0.
13EF:0140  31 39 39 35 20 68 97 5A-00 20 88 45 20 4D 01 20   1995 h.Z. .E M.
经验证算得的人均收入正确


原创粉丝点击