. : : Assembly Language : : .
|
首页
|
我提出的问题
|
我参与的问题
|
我的收藏
|
消息中心
|
游客 登录
|
刷新
|
提问
|
未解决
|
已解决
|
精华区
|
搜索
|
《汇编语言》论坛
->
CALL和RET指令
管理员:
assembly
[
回复本贴
]
[
收藏本贴
] [
管理本贴
] [
关闭窗口
]
主题 : :
10.2的call指令
[已解决]
回复[
3
次 ] 点击[
362
次 ]
742224144
[帖 主]
[ 发表时间:2012-07-31 18:41 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:4
注册日期:2012-06-25 19:51
assume cs:code
code segment
start: mov ax,0
call s
inc ax
s: pop ax
mov ax,4c00h
int 21h
code ends
end start
call不是说保存当前ip吗?所谓当前ip难道不应该是3吗?入栈ip,应该入的是3吧?那位什么执行pop后,ax=6呢?我到底哪里接错了........
fpamc
[第
1
楼]
[ 回复时间:2012-08-01 09:45 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:30
信誉值:4
注册日期:2012-01-01 16:36
call 指令保存的是本身指令的下一条指令的第一个字节的地址。
也就是inc ax的地址。
你也可以想一下'如果保存的是当前的call指令的地址,那么返回的时候还是返回到call。。那样就会一直调用,返回,调用,返回了。
书上也也说了,你可以看看书。这章的原理要有一个清晰的思路和理解哈。很重要的。
742224144
[第
2
楼]
[ 回复时间:2012-09-01 21:40 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:4
注册日期:2012-06-25 19:51
恩,谢谢
742224144
[第
3
楼]
[ 回复时间:2012-09-04 04:06 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:4
注册日期:2012-06-25 19:51
此贴由 贴主 于 [ 2012-09-04 04:06 ] 结贴。 结贴原因:问题已解决
得分情况: 1楼(fpamc):1分
此问题已结贴!
Copyright © 2006-2024 ASMEDU.NET All Rights Reserved