实验5
本帖最后由 tyyfly 于 2024-2-25 01:43 编辑以下为我的答案,不保证正确,如有错误请提出,拜托了!
(1)
assume cs:code,ds:data,ss:stack
data segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
date ends
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
code segment
start: mov ax, stack
mov ss, ax
mov sp, 16
mov ax, data
mov ds, ax
push ds:
push ds:
pop ds:
pop ds:
mov ax, 4c00h
int 21h
code ends
end start
1.CPU执行程序,程序返回前,data段中的数据为多少?
A: 23 01 56 04 89 07 bc 0a ef 0d ed 0f ba 0c 87 09
2.CPU执行程序,程序返回前,CS=___,SS=___,DS=___。
A: CS = code, SS = stack, DS = data
3.设程序加载后,code段的段地址为X,则data段的段地址为___,stack段的段地址为___。
A: X-2, X-1
(2)
assume cs:code,ds:data,ss:stack
data segment
dw 0123h,0456h
date ends
stack segment
dw 0,0
stack ends
code segment
start: mov ax, stack
mov ss, ax
mov sp, 16
mov ax, data
mov ds, ax
push ds:
push ds:
pop ds:
pop ds:
mov ax, 4c00h
int 21h
code ends
end start
1.CPU执行程序,程序返回前,data段中的数据为多少?
A: 23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
2.CPU执行程序,程序返回前,CS=___,SS=___,DS=___。
A: CS = code, SS = stack, DS = data
3.设程序加载后,code段的段地址为X,则data段的段地址为___,stack段的段地址为___。
A: X-2, X-1
4.
name segment
...
name ends
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为___。
A:(N/16 + 1)*16此答案錯誤,更正為((N+15)/16)*16
(3)
assume cs:code,ds:data,ss:stack
code segment
start: mov ax, stack
mov ss, ax
mov sp, 16
mov ax, data
mov ds, ax
push ds:
push ds:
pop ds:
pop ds:
mov ax, 4c00h
int 21h
code ends
data segment
dw 0123h,0456h
data ends
stack segment
dw 0,0
stack ends
end start
1.CPU执行程序,程序返回前,data段中的数据为多少?
A: 23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
2.CPU执行程序,程序返回前,CS=___,SS=___,DS=___。
A: CS = code, SS = stack, DS = data
3.设程序加载后,code段的段地址为X,则data段的段地址为___,stack段的段地址为___。
A:X+3, X+4
(4)
如果将(1),(2),(3)题中的最后一条伪指令"end start"改为"end"(也就是说,不指明程序的入口),则哪个程序仍然可以正确执行?请说明原因。
A:第三题即便将"end start"改为"end",依然能正确执行。
因为start为程序入口,即程序开始执行的地方,如果没有注明入口, 则程序将从程序的开头开始执行,
而第三题程序的开头即是指令,所以依然能正确执行。
(5)
程序如下,编写code段中的代码,将a段和b段中的数据依次相加,将结果存到c段中。
assume cs:code
dataA segment
db 1,2,3,4,5,6,7,8
dataA ends
dataB segment
db 1,2,3,4,5,6,7,8
dataB ends
dataC segment
db 0,0,0,0,0,0,0,0
dataC ends
code segment
start: mov ax, dataA
mov ds, ax
mov ax, dataB
mov es, ax
mov ax, dataC
mov ss, ax
mov bx, 0
mov ax, 0
mov cx, 8
s: mov al,
add al, es:
mov ss:, al
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start
(6)
程序如下,编写code段中的代码,用push指令将data段中的前8个字型数据,逆续存储到stack段中。
assume cs:code
data segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
data ends
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
code segment
start: mov ax, data
mov ds, ax
mov ax, stack
mov ss, ax
mov sp, 16
mov bx, 0
mov cx, 8
s: push
add bx, 2
loop s
mov ax, 4c00h
int 21h
code ends
end start 本帖最后由 ms1234 于 2022-8-18 23:32 编辑
好的,谢谢
我发现个问题,没有assume的段是放在一个段中的,也就是说abc的段都是一样的,不同的是偏移地址。
能解释下(2)-4的答案么?N是字节数而不是段地址,除以16后加1是加的什么?还有乘以16是为啥 本帖最后由 tyyfly 于 2024-4-2 17:52 编辑
就当我没说 发表于 2024-2-6 23:54
能解释下(2)-4的答案么?N是字节数而不是段地址,除以16后加1是加的什么?还有乘以16是为啥
我的答案不完全正確,(N/16+1)*16,當中N/16是取商然後+1,再乘16是因為一個段的最小單位是16個字節,即便N不足16,內存中開的空間還是16字節。
但我沒考慮到N=16的情況,按照我的答案,若N等於16時,就會開到2個段,也就是32個字節了(白白浪費16個字節)。
因此更好的答案應該是((N+15)/16)*16,即便N=16,開的內存單元也會是16個字節。
(N/16+1)*16
=(N/16+16/16)*16
=((N+16)/16)*16
此時N=16時會多開一個段,浪費空間,因此要讓N=16時不開下一個段,就讓前面在N=16的倍數時不進位即可。
所以得
((N+15)/16)*16
另外,感謝大哥指點錯誤{:10_297:}
页:
[1]