函数内返回值与函数外返回值不相同问题
今天在测试某个函数的返回值时发现一个奇怪的问题
int * test(int * input)
{
int output[100];
for(int i = 0;i<100;i++)
{
output[i] = intput[i];
printf("output[i] = %d\r\n",output[i]);
}
}
void main()
{
int input_data[100];
int* output_data;
for(int i = 0;i<100;i++)
{
input_data[i] = i;
}
output_data = test(intput_data);
for(int i = 0;i<100;i++)
{
printf("output_data[i] = %d\r\n",output_data[i]);
}
}
具体案例如上图。当我打印时发现,返回值函数内部的output中的值和外部返回的值output_data不一致。
解释
思来想去,觉得是函数在执行完后,会将函数内部的空间给释放,而test函数返回的只是一个地址。假设刚好此时在别的地方定义了一些变量,而这些变量恰好又申请了output[0]~output[99]之间的空间,就会导致出现数值不一致的情况。这片空间已经不属于它了。
tip:一般来说我们的计算机空间足够大,可能运行很多很久都未必能发生这种情况(但也不建议这样写),我的情况是在stm32单片机上运行,栈空间比较小,所以内存在时间上看复用率就会特别高,所以才会出现上述的问题。
解决方法
使用malloc函数去开辟一片堆空间,然后在函数结束时返回地址即可,因为函数、局部变量等都在栈空间,所以函数结束时只会回收函数内申请栈空间的内存,并不会处理申请堆空间的内存。