网站建设资讯

NEWS

网站建设资讯

c语言函数调取二维数组 c++函数调用二维数组

如何通过函数调用二维数组

C语言编程的过程中,不可避免的会碰到二维或二维以上的数组作为函数的形参的情况,在以前的编程过程中,习惯了动态数组的应用,很是使用直接定义高维数组。最近在编程的过程中就碰到了这个问题:有如下的测试程序:

久治网站建设公司成都创新互联公司,久治网站设计制作,有大型网站制作公司丰富经验。已为久治1000+提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的久治做网站的公司定做!

voidtest(double  **x,int Row,int Col);

voidtest(double  **x)

{

for(int i=0;iRow;i++)

for(int k=0;kCol;k++)

x[i][k] += 100.0;

}

intmain(int argc, char *argv[])

{

/*

double **x;

x = new double *[3];

for(int i=0;i3;i++)

x[i] = new double[3];

*/

double x[3][3];

for(int i=0;i3;i++)

for(int k=0;k3;k++)

x[i][k] = i*k;

test(x,3,3);

for(int i=0;i3;i++)

for(int k=0;k3;k++)

printf("x[%d][%d]= %e\n",i,k,x[i][k]);

getch();

return 0;

}

编译时提示Cannot convert 'double [*][3]' to double **'。

将调用方式强制进行类型转换:test((double **)x),编译通过,运行出错,提示非法越界。

据传:因为栈上分配的数组和堆上分配的数组在内存排列上可能不相同,直接定义的数组是存储在程序的堆栈区,数据占用连续的区间;而动态申请的数组是在系统的远堆上(far heap),除最后一维的元素是连续存放的外,其他维上的元素有可能不是在一块连续的内存区域里。

//栈上: 

int   ia[2][2]   = {2,3,4,5};    //4个元素是连续排列的内存段 

//堆上: 

int   **p  =  new  int*[2];   //只有每行内是连续排列,各行并不一定连续排列 

for ( int  i  = 0;  i   2; i++ ) 

p[i]   =  new  int[2]; 

for ( int  i  =  0;  i    2;  i++ ) 

for ( int  j  =  0;  j    2;  j++ ) 

p[i][j]   =   ia[i][j]; 

所以对栈上的数组用int  **p指向首地址,因为int  **p一次解引用为地址指针,而非堆上的指向数组的指针,所以二次解引用会出错。 

如果找一个通用方程只能用: 

void   f( int  *p, int  row,  int  col )     //给出数组的行和列,对堆上的数组不合适   

for ( int  i =  0;  i    row;  i++) 

for ( int  j  =  0;  j   col;  j++ ) 

cout   p[i * row + j]   "   ";                        

cout   endl; 

int   main(){ 

//......... 

int   ia[2][2]   =  {2,3,4,5}; 

f( (int*)ia, 2, 2 ); 

}

采用上面的通用办法还是比较麻烦,这无形中对编程增加了难度,为了避免这个麻烦可以采用动态数组的形式,将原来采用直接定义的数组全部换成动态数组,类似开头例子中被注释掉的那部分代码,当然这样也有后续的麻烦,动态数组的生命周期完成后必须释放内存空间,这也有点罗嗦,但是毕竟可以直接使用数组的形式,比上面的通用方式还是要简单一点。

如果执意要使用直接定义的数组该怎么办呢?有如下几种方法:

方法一:

voidtest(double  (*x)[3], int Row, int Col);

调用方式:test(x,Row,Col);

调用用方式 test(x,Row,Col);

方法二:

voidtest(double  x[][3], int Row,int Col);

调用方式 test(x,Row,Col);

对于多维数组作为参数,除第一维之外的其它维必须指定维数,否则是肯定编译不过去的。

从上面的对直接定义的数组的引用情况看,直接定义的数组的使用比较麻烦,一旦直接定义数组的维数发生变换,函数的定义必须相应的修改,否则程序就会出错,这也增加了程序进一步开发的麻烦,为了一劳永逸的解决这个问题,建议还是使用动态数组的方法,虽然需要手工释放内存,但是除却了后续的麻烦。

C语言函数传递二维数组

C语言如果给函数传递二维数组作为参数

先看一个传递二维数组的例子:

编译:

程序看着没有任何问题,但是编译器通不过,报错在处理二维数组参数a的时候,类型不兼容。

C语言里面对二维数组的存储是按照一维数组来处理的,二维数组按照行展开的方式按顺序存储,例如在上面的例子中:

二维数组a的定义:

它等同于一维数值的定义:

因为他们的空间存储分配一样的。

所以在利用二维数组作为参数传递时,必须指定二维数组的列数,否则函数无法勾画出二维数组的组织形式。只有有了列长度,通过下标a[i][j]时才能得到正确的下标地址,即:

我们改一下上面的额foo函数定义:

编译运行:

这下就正常了。

参数如上所列。

我们看到,函数的参数声明改成了:

这个声明的含义是:

不过此时还是需要指定二维数组的列长度,不然函数内部还是无法使用二维下标去访问数组:

编译:

原因同前面方法1一致,如果要访问二维数组,必须指定列的长度,否则无法计算出该元素的地址,a[i][j]=a [ (i-1)*COLNUM + j ],如果没有COLNUM,那么这个地址无法计算出来。从形参的声明来说,a就是一个指针,指向一维数组的指针,而不是一个二维数组。

这里要注意的是指针的指针,和二维数组的差异;二维数组的地址是连续的,所有成员按顺序排序;而指针的指针只要求指针地址连续,而不要求指针的指针地址连续。

然后作为实参传递时,也不能直接使用a传递,因为类型不匹配,必须定义新的变量p,然后把a的值赋给p,再传递给foo函数。

C语言函数中怎么返回一个二维数组

1、我们首先定义一个二级指针和一个行列变量[int ** array,row,column;]。

2、然后我们编写进入行和列的语句,代码如图所示。

3、接下来我们可以用一维数组打开一维一维数组。

4、接下来,我们使用[array [i] =(int *)malloc(sizeof(int)* column);]来为数组再次生成包含该数组的新数组。

5、然后我们可以为它赋值并输出[代码如图所示]。

6、运行程序后我们可以看到这种效果。

C语言函数调用二维数组,指针问题

正如

楼下

所言

int

**p

,定义的p是一个指向int*型的

指针

int

(*p)[10]是一个指向

数组

的指针

数组长度为10

假如定义成

deal(int

**p),传

参数

时要加强制类型转换:

deal((int**)a);

并且使用p时不能用

下标

,p[2][3]是错误的,因为不知道p指向的int*型的长度,无法编译成*(p+2*10+3)

必须自己写成*(p+2*10+3)来调用

假如定义成

deal(int

(*p)[10])就不一样了,

编译器

就能知道p是一个指向长度为10的数组的指针

那么p[2][3]就能编译成*(p+2*10+3)了

总之,C语言是很灵活的,不同的定义

方式

配上不同的

用法

,都是能得到正确的结果的

不知道这么说楼主明白了没?

同样的还有

多维数组

对多维指针的问题,楼主可以自己类推一下

C语言二维数组的函数调用

函数调用不能这么用,第36行。C标准里面返回值是不能直接返回一个数组的,只能返回数组的首地址。输出学生成绩和每科成绩那个函数,你可以定义一个全局变量数组,还有求平均值最好用float 或者double,用int会造成精度流失。帮你调试了一下,大概就这样吧


名称栏目:c语言函数调取二维数组 c++函数调用二维数组
当前链接:http://cdweb.net/article/hhgdcs.html