你想返回一个数组,因为你在一个函数内创建了数组,属于局部变量,所以他在stack部分,而stack部分是用后类似于销毁的,你返回的地址类似于一块垃圾的地址,所以编译警告。你要想返回函数内创建的数组地址的话需要
//inside a function{
// n is the size of the array
int* array = (int *)malloc(sizeof(int)*n)
/*
do something with array
*/
return array
}
这样这个数组建立在heap堆上,调用完函数还在,而你返回了那个堆上数组的首地址,这样就没问题了。
用完free(array)
楼上用static不推荐,用static的话会在整个程序的run time运行时都占用空间。而是用malloc,动态申请释放更合理。
C/C++不能直接返回一个数组。这是由于在C/C++中,数组不是一种类型,因此不能被直接返回。在C/C++中,一般有两种方法来返回一个数组。第一种方法:返回一个指向数组的指针,例如char (*retArray)[10]声明了一个函数retArray,该函数可以返回指向具有10个char元素的数组例子如下:#include#includeint (*retArray())[10]{int (*a)[10]int i=0/*动态开辟空间*/a=calloc(10,sizeof(int))/*赋值*/for(i=0i<10i++){(*a)[i]=i}return a}int main(){int (*b)[10]/*函数返回指向数组的指针*/b=retArray()/*打印第一个元素*/printf("%d/n",(*b)[0])/*释放空间*/free(b)return 0}第二种方法:如果你不喜欢用指针的形式返回数组,那么可以采用返回一个结构的形式。这种形式相对较安全,可以避免忘记释放指针而造成内存泄露,也可以避免访问悬挂指针造成的错误。但缺点是由于结构是先拷贝再返回,因此如果结构较大时,会影响效率和占用较大内存。例子如下:#includestruct tag{int a[10]}x,ystruct tag retArray(){int i=0for(i=0i<10i++)x.a[i]=ireturn x}int main(){struct tag y=retArray()printf("%d/n",y.a[3])return 0}注意:(1)在返回指针时要切记要避免内存泄露和访问悬挂指针。(2)很多人认为指针和数组等价的,这是错误的。int (*a)[10]和int b[10]两者是不能直接用a=b来赋值的。在数组和指针作为函数参数传递时,二者可以认为等价,这是因为数组会被转化为指针来传递。(3)返回多维数组方法类似。不能直接返回一个数组,但是可以用其他方式实现类似功能。方法1:利用全局变量
分析:全局变量作为C语言的一个知识点,虽然我们都了解它的特点,但在实际教学过程中应用得并不是很多。由于全局变量的作用域是从定义变量开始直到程序结束,而对于编写有多个返回值的C语言函数,我们可以考虑把要返回的多个值定义成全局变量。当函数被调用时,全局变量被更改,我们再把更改后的全局变量值应用于主调函数中。函数被调用后被更改后的全局变量值即为函数的数个返回值。下面以一个实例演示该方法的应用。
实例1:编写函数求3个数中的最大值与最小值。
方法:把最大值、最小值分别定义成2个全局变量max、min,在用户自定义函数中把求出来的最大值与最小值分别赋给全局变量max、min。函数调用完毕后全局变量的max、min值即保存了函数要求返回的值。程序参考代码如下:
#include "stdio.h"
#include "conio.h"
int max,min/*定义两个全局变量用于保存函数返回值*/
void max_min(int a,int b,int c) /*定义求最大最小值的函数*/
{max=min=a/*初始化最大最小值*/
if(max if(max if(min>b)min=b
if(min>c)min=c
}
main()
{int x,y,z
printf(" 请输入3个整数:\n")
scanf("%d,%d,%d",&x,&y,&z)
max_min(x,y,z) /*调用求最大值与最小值的函数*/
printf("三个数中的最大值为:%d最小值为:%d",max,min)/*输出最大值与最小值*/
getch()
}
调试结果如下:
请输入3个整数:
5,-6,2
三个数中的最大值为:5最小值为:-6
注意:该方法虽然可以实现有多个返回值的函数,但由于全局变量不能保证值的正确性(因为其作用域是全局,所以程序范围内都可以修改它的值,如果出现错误将非常难以发现),并且全局变量增加了程序间模块的耦合,所以该方法要慎用。
方法2:传递数组指针
分析:在教学过程中,我们知道C语言函数参数的传递方式有值传递与地址传递。当进行值传递时,主调函数把实参的值复制给形参,形参获得从主调函数传递过来的值运行函数。在值传递过程中被调函数参数值的更改不能导致实参值的更改。而如果是地址传递,由于传递过程中从实参传递过来的是地址,所以被调函数中形参值的更改会直接导致实参值的更改。因此,我们可以考虑把多个返回值作为数组元素定义成一个数组的形式,并使该数组的地址作为函数的形式参数,以传址方式传递数组参数。函数被调用后,形参数组元素改变导致实参改变,我们再从改变后的实参数组元素中获得函数的多个返回值。以下实例演示该方法的应用。
实例2:编写函数求一维整形数组的最大值与最小值,并把最大值与最小值返回给主调函数。
方法:以指针方式传递该一维数组的地址,然后把数组的最大值与数组的第一个元素交换,把数组的最小值与最后一个元素交换。函数被调用完毕后,实参数组中的第一元素为数组的最大值,实参数组中最后一个元素为数组的最小值,从而实现返回数组的最大值与最小值的功能。程序参考代码如下:
#include "stdio.h"
#include "conio.h"
void max_min(int *ptr,int n) /*定义求数组最大值最小值的函数,传递数组指针*/
{int i,j,k/*j保存最大值所在位置,k保存最小值所在位置*/
int *temp/*用于交换位置*/
*temp=*ptr
for(i=0i{
if(*ptr<*(ptr+i))/*最大值与第一个元素进行交换*/
{
k=i
*temp=*ptr
*ptr=*(ptr+k)
*(ptr+k)=*temp
}
if(*(ptr+n-1)>*(ptr+i))/*最小值与最后一个元素进行交换*/
{
j=i
*temp =*(ptr+n-1)
*(ptr+n-1)=*(ptr+j)
*(ptr+j)= *temp }
}
}
/*调用最大最小值函数*/
main()
{
int A[6],i
for(i=0i<6i++)
scanf("%d",&A[i])
max_min(A,6)
printf("max=%d, min=%d\n \n",A[0],A[5])
getch()
}
调试结果如下:
请输入6个整形数,以空格隔开:
5 8 9 32 -6 4
max=32,min=-6
注意:该方法适用于多个返回值的数据类型一致的情况。当返回值数据类型不一致时,不适用该方法