第21节:要点回顾(函数、参数、返回值)
1、什么是函数,函数就是一堆指令,这个指令实现的一个功能,这个功能可以反复使用。那么我就可以把这个功能写成一个函数,这样下次用的时候可以拿来用,那么什么是函数调用呢?比如:见到CALL的时候,CALL就是函数调用,那么什么是参数呢?如下:
00148FFDC ADD ECX,EDX
MOV EAX,ECX
RET
2、那调用函数的时候使用CALL,那么调用传递参数呢?比如两个函数是实现任何两个整数相加,那么这两个整数放在哪里呢?如下:
MOV ECX,1
MOV EDX,2
CALL 00148FFDC
当执行到CALL 00148FFDC的时候,EAX就是要返回的值,这些概念从汇编的角度很好理解,现在有个新的问题出现,如果从1加到5通用的寄存器就不够用了,这时候我们要把1到10的数据存储到堆栈中去,代码如下:
PUSH 1
PUSH 2
PUSH 3
PUSH 4
PUSH 5
CALL 0014489FD
001489FD MOV EAX,DWORD PTR DS:[ESP+14]
MOV EAX,DWORD PTR DS:[ESP+10]
MOV EAX,DWORD PTR DS:[ESP+0xC]
MOV EAX,DWORD PTR DS:[ESP+8]
MOV EAX,DWORD PTR DS:[ESP+4]
RET
以上就是使用堆栈传递参数,最终的结果是:5+4+3+2+1=15(转换成十六进制是0000000F)。
1、什么是函数,函数就是一堆指令,这个指令实现的一个功能,这个功能可以反复使用。那么我就可以把这个功能写成一个函数,这样下次用的时候可以拿来用,那么什么是函数调用呢?比如:见到CALL的时候,CALL就是函数调用,那么什么是参数呢?如下:
00148FFDC ADD ECX,EDX
MOV EAX,ECX
RET
2、那调用函数的时候使用CALL,那么调用传递参数呢?比如两个函数是实现任何两个整数相加,那么这两个整数放在哪里呢?如下:
MOV ECX,1
MOV EDX,2
CALL 00148FFDC
当执行到CALL 00148FFDC的时候,EAX就是要返回的值,这些概念从汇编的角度很好理解,现在有个新的问题出现,如果从1加到5通用的寄存器就不够用了,这时候我们要把1到10的数据存储到堆栈中去,代码如下:
PUSH 1
PUSH 2
PUSH 3
PUSH 4
PUSH 5
CALL 0014489FD
001489FD MOV EAX,DWORD PTR DS:[ESP+14]
MOV EAX,DWORD PTR DS:[ESP+10]
MOV EAX,DWORD PTR DS:[ESP+0xC]
MOV EAX,DWORD PTR DS:[ESP+8]
MOV EAX,DWORD PTR DS:[ESP+4]
RET
以上就是使用堆栈传递参数,最终的结果是:5+4+3+2+1=15(转换成十六进制是0000000F)。