1、寄存器法
最常用的方法,使用方便,由于cpu寄存器个数的限制,一般用于参数较少的情况。实现方法是在主程序中把要传递的参数放在某一指定的寄存器中,然后从子程序中取出指定的寄存器参数。
2、约定单元法:
入口参数和出口参数都放在事先约定好的单元中,子程序可以直接访问该变量。
优点:不占用寄存器、参数个数任意、每个子程序要处理的数据和送出的结构都有独立的存储单元。
缺点:占用一定数量的存储单元,增加编程中对变量定义的难度。
3、堆栈法
堆栈法是利用堆栈来传递参数的,适用于参数多、子程序嵌套调用和递归调用的情况,调用前先将参数压入堆栈,子程序从堆栈中取出参数。
优点:参数不占用寄存器,和存储单元。参数存放在公共堆栈区,处理完后客恢复。参数个数一般不限
缺点:由于参数和子程序混杂在一起,存取参数时候必须小心计算它在堆栈中的位置。要注意断点的保存和恢复。
4、参数表法
这种方法是把参数组成的一张参数表放在内存或者外设中,然后用寄存器将表地址传递给子程序。适用于大量参数的传递。