#include<stdio.h>
int **returnNum()
{
int a[5][5],i,j;
for(i=0;i<5;++i)
for(j=0;j<5;++j)
{
a[i][j]=i;
}
return a;//error: cannot convert `int (*)[5]' to `int**' in return
}
int main()
{
//int cpy[5][5]=returnNum; // error: invalid initializer
int **cpy=returnNum;//error: cannot convert `int**(*)()' to `int**' in initialization
return 0;
}
1、我们首先定义一个二级指针和一个行列变量[int ** array,row,column;]。
2、然后我们编写进入行和列的语句,代码如图所示。
3、接下来我们可以用一维数组打开一维一维数组。
4、接下来,我们使用[array [i] =(int *)malloc(sizeof(int)* column);]来为数组再次生成包含该数组的新数组。
5、然后我们可以为它赋值并输出[代码如图所示]。
6、运行程序后我们可以看到这种效果。
c语言无法返回空间,只能返回指针。
函数内动态申请,返回指针,缺点是容易出现野指针,根据谁申请谁释放原则。
设置全局参数,缺点全局数据稍微多了一些,而且破坏封装思想。