当前位置: 首页 > news >正文

[总结]C语言二维数组作为函数的参数

  前言:今天在实现装配线调度程序时候,用到了二维数组,并将其作为函数的参数。在写程序的时候,遇到一些问题,即二维数组做函数的参数应该如何正确表示。我写程序的错误如下程序所示:

复制代码
 1 #include <cstdio>
 2 void print(int *a[3])
 3 {
 4     printf("%d\n",a[0][0]);
 5 }
 6 
 7 int main()
 8 {
 9     int a[2][3] = {1,2,3,4,5,6};
10     print(a);
11     return 0;
12 }
复制代码

编译程序时候,在第10行提示错误信息:|10|error: cannot convert 'int (*)[3]' to 'int**' for argument '1' to 'void print(int**)'|。根据错误提示我明白了,   int *a[3]表示一个一维数组,数组的数据类型为整型指针(int*),数组的大小为3,这是因为[]的优先级高于*的优先级。如是我将程序改写如下,顺利通过编译,得到正确结果。

复制代码
 1 #include <cstdio>
 2 void print(int (*a)[3])     //用括号将指针括起来
 3 {
 4     printf("%d\n",a[0][0]);
 5 }
 6 
 7 int main()
 8 {
 9     int a[2][3] = {1,2,3,4,5,6};
10     print(a);
11     return 0;
12 }
复制代码

下面来总结一下二维数组作为函数参数该如何表示。

1、二维数组的概念

  在C语言中,二维数组实际上是一种特殊的一维数组,它的每个元素也是一个一维数组。因此,二维数组下标形式正确写法如下:int arrays[i][j]。数组元素是按照行顺序存储的,因此当按存储顺序访问树时,最右边的数组下标(列)变化的最快。

2、二维数组作为函数参数

  规定:如果将二维数组作为参数传递给函数,那么在函数的参数声明中必须指明数组的列数,数组的行数没有太大关系,可以指定也可以不指定。因为函数调用时传递的是一个指针,它指向由行向量够成的一维数组。因此二维数组作为函数参数正确写法如下所示:   

void Func(int array[3][10]); 

void Func(int array[ ][10]);

因为数组的行数无关紧要,所以还可以写成如下形式:

void Func(int (*array)[10]);  注意*array需要用括号括起来。

这种形式的声明参数是一个指针,它指向具有10个元素的一维数组。因为[]的优先级比*的优先级高,故*array必须用括号括起来,否则变成了

void Func(int *array[10]);

这时候参数相当于是声明了一个数组,该数组有10个元素,其中每个元素都是一个指向整型对象的指针。

但是不能把第二维或者更高维的大小省略,如下面的定义是不合法的:

 void Func(int array[ ][ ]);

  因为从实参传递来的是数组的起始地址,在内存中按数组排列规则存放(按行存放),而并不区分行和列,如果在形参中不说明列数,则系统无法决定应为多少行多 少列,不能只指定一维而不指定第二维,下面写法是错误的: 

void Func(int array[3][ ]);

  实参数组维数可以大于形参数组,例如形参数组定义为: 

 void Func(int array[3][10]); 

而实参数组定义为:int array[5][10];     进行函数调用Func(array)时,由于数组在内存中是连续存放的,虽然形参与实参数组行数不对应,但是列数是相同的,具有相同的起始地址,这样可以访问到后续的值。如下述程序:

复制代码
 1 #include <stdio.h>
 2 
 3 void print_array(int *array, int len)
 4 {
 5     int i = 0;
 6     for ( ; i < len; i++) {
 7         printf("%d ",array[i]);
 8     }
 9     putchar('\n');
10 }
11 
12 void func(int array[3][10])
13 {
14     print_array(array[0], 10);
15     print_array(array[1], 10);
16     print_array(array[2], 10);
17     print_array(array[3], 10);
18     print_array(array[4], 10);
19 }
20 
21 int main()
22 {
23     int array[5][10] = {
24         {0,1,2,3,4,5,6,7,8,9},
25         {10,11,12,13,14,15,16,17,18,19},
26         {20,21,22,23,24,25,26,27,28,29},
27         {30,31,32,33,34,35,36,37,38,39},
28         {40,41,42,43,44,45,46,47,48,49}
29     };
30     func(array);
31     return 0;
32 }
复制代码

相关文章:

  • UVa12169 Disgruntled Judge
  • 【原创】MySQL Proxy - Administration Interface
  • 详解6大安全场景:移动app安全、防DDoS、防入侵、数据加密、业务反欺诈、内容安全...
  • linux ulimit 的设置
  • 二次登陆验证
  • 电脑配置
  • 解决spring jpa中配置文件报'jpa:repositories'的问题
  • 启用约束时使用exceptions表来跟踪不符合约束的数据并修正
  • Combination Sum系列问题
  • js中容易被忽视的事件问题总结
  • Web Service 接口安全与解决方案
  • B树、B-树、B+树、B*树的定义和区分
  • 史上最全大数据学习资源整理(1)
  • Hive操作表部分总结
  • 电邮欺诈需重视 TurboMail邮件系统保护您
  • [译]CSS 居中(Center)方法大合集
  • extjs4学习之配置
  • Hibernate最全面试题
  • LeetCode18.四数之和 JavaScript
  • leetcode388. Longest Absolute File Path
  • php ci框架整合银盛支付
  • PHP 小技巧
  • Shell编程
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 关于Java中分层中遇到的一些问题
  • 湖南卫视:中国白领因网络偷菜成当代最寂寞的人?
  • 猫头鹰的深夜翻译:JDK9 NotNullOrElse方法
  • 浅析微信支付:申请退款、退款回调接口、查询退款
  • 如何借助 NoSQL 提高 JPA 应用性能
  • 如何优雅地使用 Sublime Text
  • 用 Swift 编写面向协议的视图
  • 正则学习笔记
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • Nginx实现动静分离
  • ​一文看懂数据清洗:缺失值、异常值和重复值的处理
  • #pragma预处理命令
  • (3)(3.5) 遥测无线电区域条例
  • (C语言)球球大作战
  • (二)linux使用docker容器运行mysql
  • (附源码)node.js知识分享网站 毕业设计 202038
  • (附源码)springboot 个人网页的网站 毕业设计031623
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (附源码)ssm考生评分系统 毕业设计 071114
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (三)elasticsearch 源码之启动流程分析
  • (原)本想说脏话,奈何已放下
  • (最完美)小米手机6X的Usb调试模式在哪里打开的流程
  • .net core 调用c dll_用C++生成一个简单的DLL文件VS2008
  • .NET大文件上传知识整理
  • @SuppressLint(NewApi)和@TargetApi()的区别
  • [ Linux 长征路第二篇] 基本指令head,tail,date,cal,find,grep,zip,tar,bc,unname
  • [ web基础篇 ] Burp Suite 爆破 Basic 认证密码
  • [\u4e00-\u9fa5] //匹配中文字符
  • [AIGC] 如何建立和优化你的工作流?
  • [Asp.net MVC]Bundle合并,压缩js、css文件