【笔记】【汇编语言】第10章 CALL和RET指令

10.0 概述
  call和ret指令都是转移指令,它们都修改IP,或同时修改CS和IP。它们经常被用来共同实现子程序的设计。
 
10.1 ret和retf
  ret指令用栈中的数据,修改IP的内容,即相当于
  pop IP
  retf指令用栈中的数据,修改CS和IP的内容,即相当于
  pop IP
  pop CS
 
10.2 call指令
  CPU执行call指令时,进行两步操作
  1) 将当前的IP或CS和IP压入栈中
  2) 转移
  call指令不能实现短转移,除此之外,call指令实现转移的方式与jmp指令的原理相同。
 
10.3 依据位移进行转移的call指令
  call 标号 ;(将当前IP压栈,转到标号处开始执行)
  此操作相当于:
  push IP
  jmp near ptr 标号
 
10.4 转移的目的地址在指令中的call指令
  call far ptr 标号 ;(实现段间转移)
  此操作相当于:
  push CS
  push IP
  jmp far ptr 标号
 
10.5 转移地址在寄存器中的call指令
  call reg16
  相当于:
  push IP
  jmp reg16
 
10.6 转移地址在内存中的call指令
  1) call word ptr 内存单元地址
  相当于:
  push IP
  jmp word ptr 内存单元地址;(段内转移)
  2) call dword ptr 内存单元地址
  相当于:
  push CS
  push IP
  jmp dword ptr 内存单元地址;(段间转移)
 
10.7 call和ret的配合使用
  可以利用call和ret来实现子程序的机制。
 
10.8 mul指令
  mul指令是乘法指令,使用时应注意:
  (1) 两个相乘的数:要么都是8位,要么都是16位。如果是8位,一个默认放在AL中,另一个放在8位reg或内存字节单元中;如果是16位,一个默认放在AX中,另一个放在16位reg或内存字单元中。
  (2) 结果:如果是8位乘法,结果默认存放在AX中;如果是16位乘法,结果高位默认在DX中存放,低位在AX中存放。

10.9 模块化程序设计
  call和ret指令共同支持了汇编语言编程中的模块化设计。
 
10.10 参数和结果传递的问题
  用寄存器来存储参数和结果是最常用的方法。调用者将参数送入参数寄存器,从结果寄存器中取到返回值。子程序的读写动作正好相反。
 
10.11 批量数据的传递
  对于批量数据,可以将批量数据存放到内存中,然后将它们所在的内存空间首地址放在寄存器中,传递给需要的子程序。
  对于具有批量数据的返回结果,也可以用此方法。
  注:除了用寄存器传递参数外,还可以使用栈传递参数。参见附注4
 
10.12 寄存器冲突的问题
  编写子程序时,可先将子程序用到的寄存器入栈,过程结束后,再将这些寄存器出栈恢复。
 
实验10 编写子程序
  1.显示字符串
  2.解决除法溢出的问题
  3.数值显示
 
课程设计1
  略

posted @ 2012-05-23 13:40  Azik  阅读(454)  评论(0编辑  收藏  举报