本文共 720 字,大约阅读时间需要 2 分钟。
大家都知道函数的返回值是在函数退栈的时候通过eax这个寄存器传递出去的,例如,函数返回一个int型的变量,那么函数在执行完的时候,会将返回值存入到eax寄存器,调用方将eax内内容存入到指定的变量就可以了,那么如果返回值是一个非常大size的变量时该怎么办呢,例如,函数返回一个结构体,或者一个对象,或者一个数组。
大家看下面一个例子
typedef struct big_thing{char buf[128];}big_thing;big_thing return_test(){big_thing b;b.buf[0] = 0;return big_thing;}int main(){big_thing n = return_test();}
在这里, main函数调用的return_test()函数会返回一个size比较大的结构体。
那么是怎么实现的呢?
1 main函数在栈中开辟一片临时空间,存放返回值,就相当于定义了一个临时变量 big_thing temp.
2 main函数通过寄存器将该临时变量的首地址传给被调用的函数return_test.
3 retturn_test函数执行完之后,将需要返回值拷贝到main函数开辟好的临时内存 temp中, 并将temp的首地址用eax寄存器传出。
4 main函数将临时变量temp复制给接收返回值的变量n。
在这里可以看到,在传递返回值的时候,发生了两次拷贝,一次是被调函数将返回值从该函数内拷贝到main函数开辟好的临时变量temp中,另外一次是将temp临时变量拷贝到接收返回值的变量n中。(这个n的地址可以在任何地方,不在main之内,所以需要一个临时变量存储)。
转载地址:http://zutsi.baihongyu.com/