. : : Assembly Language : : .
|
首页
|
我提出的问题
|
我参与的问题
|
我的收藏
|
消息中心
|
游客 登录
|
刷新
|
提问
|
未解决
|
已解决
|
精华区
|
搜索
|
《汇编语言》论坛
->
转移指令的原理
管理员:
assembly
[
回复本贴
]
[
收藏本贴
] [
管理本贴
] [
关闭窗口
]
主题 : :
讨论贴 检测题9.1 (2) 三大疑点
[待解决]
回复[
3
次 ] 点击[
635
次 ]
zhenglxd
[帖 主]
[ 发表时间:2009-05-12 11:16 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:30
信誉值:0
注册日期:2009-04-09 10:05
不是说题目本身而是说实现方式上
1. 为什么 mov [bx],word ptr 0 是可以通过编译的 而mov [bx+2],word ptr start就不行
仅讨论方法 0是个数值 start是个偏移地址 其实也是个数值
2 为什么 mov bx[2],bx+2在debug中是合法的 而 在源程序中就非法呢? 我的理解是 bx[2]表示一个内存单元,而bx+2中bx表示了寄存器代表了这个数值是 16位的 bx+2其实就是bx=bx+2
3内存单元不可以直接交换信息 他们必须通过寄存器 因为内存单元的物理结构不允许 那么栈是怎么实现的 栈是否也是 通过寄存器来实现的 只是不直接显示出来而已?
changkong
[第
1
楼]
[ 回复时间:2009-06-08 23:47 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:6
信誉值:2
注册日期:2007-12-28 19:04
回答你:
1.肯定不行哈!因为start是程序的入口地址.就这么简单.你可以看一下前面专门介绍.start的章节
2.我想[bx+2]在源程序中是合法的.因为源程序和debug本来就有点差异.
3.内存单元不能直交换信息.只能通过寄存器来中转.当然了.32位或者64位就可以不用中转了.栈是通过ss:sp的栈机制来实现的.cpu提供了这方面的栈机制.任何cpu都有.
zhy_zhy
[第
2
楼]
[ 回复时间:2009-07-23 17:21 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:2
注册日期:2009-06-29 14:39
楼主很细心哦!第二个在源程序中怎样写才能得到一样的结果呢?高手看下
nick
[第
3
楼]
[ 回复时间:2009-08-25 16:16 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2009-08-17 01:35
mov bx[2],bx+2
变成
mov [bx][2],[bx+2]
源程序就合法了
需要登录后才能回帖 -->>
请单击此处登录
Copyright © 2006-2024 ASMEDU.NET All Rights Reserved