C/C++二维数组的传参方法总结
2015-09-10 17:07
736 查看
C/C++二维数组的传参方法总结
转自:/article/1622079.htmlC/C++语言将二维数组作为参数传递容易使人迷惑且易出错,本文将常用的几种方法列出,以方便用时查阅。三+一种方法总结如下(GCC验证成功):
方法一:形参为二维数组并给定第二维长度
此方法是最简单最直观的方法,形参与实参一样,容易理解。
举例:
[cpp] view
plaincopy
#include <stdio.h>
void subfun(int n, char subargs[][5])
{
int i;
for (i = 0; i < n; i++) {
printf("subargs[%d] = %s\n", i, subargs[i]);
}
}
void main()
{
char args[][5] = {"abc", "def", "ghi"};
subfun(3, args);
}
方法二:形参为指向数组的指针并给出数组长度
举例
[cpp] view
plaincopy
#include <stdio.h>
void subfun(int n, char (*subargs)[5])
{
int i;
for (i = 0; i < n; i++) {
printf("subargs[%d] = %s\n", i, subargs[i]);
}
}
void main()
{
char args[][5] = {"abc", "cde", "ghi"};
subfun(3, args);
}
方法三:形参为指针的指针
此方法实参必须为指针,而不能为数组名
举例
[cpp] view
plaincopy
#include <stdio.h>
void subfun(int n, char **subargs)
{
int i;
for (i = 0; i < n; i++) {
printf("subargs[%d] = %s\n", i, subargs[i]);
}
}
void main()
{
char *a[3];
char args[][5] = {"abc", "def", "ghi"};
a[0] = args[0]; //equals with a[0] = &args[0][0];
a[1] = args[1];
a[2] = args[2];
subfun(3, a); //若此处为subfun(3, args);则会编译出错
}
上述代码等价于下面代码。当然我们这里只是讨论的二维数组传参问题,下面代码只起扩展作用。
[cpp] view
plaincopy
#include <stdio.h>
void subfun(int n, char **subargs)
{
int i;
for (i = 0; i < n; i++) {
printf("subargs[%d] = %s\n", i, subargs[i]);
}
}
void main()
{
char *args[] = {"abc", "def", "ghi"};//equals with char *args[3] = {"abc", "def", "ghi"};
subfun(3, args);
}
------------------------------------------------------------------------------------------------------------------------
方法四:形参为指针+数组的行+数组的列
#include <stdio.h> #include <stdlib.h> void test(double *p,const int m,const int n) { for(int i=0;i<m;i++) for(int j=0;j<n;j++) printf("%f, \n",p[i*m+j]); } int main(int argc, char *argv[]) { double a[2][2]={{1,2},{3,4}}; test((double*)a,2,2); return 0; }
但不能如下使用:原因是double** 在堆里new出来的地址并不一定是连续的,而p[i*m+j]是在访问连续地址。
#include <stdio.h> #include <stdlib.h> void test(double *p,const int m,const int n) { for(int i=0;i<m;i++) for(int j=0;j<n;j++) printf("%f, \n",p[i*m+j]); } int main(int argc, char *argv[]) { //double a[2][2]={{1,2},{3,4}}; double **a; a = new double*[2]; for(int i =0;i<2;i++) a[i] = new double[2]; //init for(int i =0;i<2;i++) for(int j =0;j<2;j++) a[i][j] = 1*i+j; for(int i=0;i<2;i++) for(int j=0;j<2;j++) printf("%f, \n",a[i][j]); test((double*)a[0],2,2); for(int i =0;i<2;i++) delete [] a[i]; delete [] a; return 0; }
相关文章推荐
- C++中const用法总结
- 动态数组new、allocate
- Connector/c++ 查询Mysql,出现 can't fetch because not on result set 错误
- C++函数的嵌套调用和递归调用学习教程
- C++用法的学习心得
- ☆C++学习心得
- c语言二目运算符. ->
- C++Primer第五版 第1章 开始(练习解答)
- C/C++ 笔试、面试题目大汇总(转)
- C++Primer 第五版 1.1节练习
- C++静态库与动态库(转)
- c++结构体字节对齐
- C/C++创建二维数组/指针数组
- C++ explicit
- C++成员变量的初始化顺序如果不使用初始化列表初始化,在构造函数内初始化时,此时与成员变量在构造函数中的位置有关。
- 【more effective c++读书笔记】【第5章】技术(7)——让函数根据一个以上的对象类型来决定如何虚化(2)
- 【more effective c++读书笔记】【第5章】技术(7)——让函数根据一个以上的对象类型来决定如何虚化(2)
- 命名空间
- HDU 5011(博弈)
- C++的学习心得