. : : 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