再学C语言41:变长数组(VLA)

2024-01-27 09:40
文章标签 语言 数组 41 再学 vla

本文主要是介绍再学C语言41:变长数组(VLA),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

处理二维数组的函数:数组的行可以在函数调用时传递,但是数组的列只能被预置在函数内部

示例代码:

#define COLS 4
int sum(int arr[][COLS], int rows)
{int r;int c;int temp = 0;for(r = 0; r < rows; r++){for(c = 0; c < COLS; c++){temp += arr[r][c];}}return temp;
}

假设定义数组array[3][4],函数调用形式为:

sum_arr = sum(array, 3); // 行数可以以参数形式传递给参量rows

这是因为数组的维数必须是常量,不能用一个变量代替COLS


C99引入变长数组,允许使用变量定义数组各维

int a = 3;
int b = 4;
int array[a][b]; // 一个变长数组

变长数组的限制:必须是自动存储类,意味着变长数组必须在函数内部或作为函数参量声明,并且声明时不可以进行初始化

变长数组的大小不会变化:变长数组的大小在创建之后保持不变,“变”的意思是数组的维数可以使用变量进行指定

1)函数声明

如何声明带有一个二维变长数组参数的函数:

int sum(int r, int c, int arr[r][c]); // arr是一个变长数组// 前面两个参量作为数组参量arr的维数// 因为arr的声明中使用了r和c// 所以r和c的声明需早于arr

C99标准规定,可以省略函数原型中的名称;如果省略名称,需用*代替省略的维数

int sum(int, int, int arr[*][*]); 

2)函数定义

int sum(int r, int c, int arr[r][c])
{int i, j;int temp = 0;for(i = 0 ; i < r; i++){for(j = 0; j < c; j++){temp += arr[i][j];}}return temp;
}

区别古典C,函数定义时,用变量c代替常量COLS,因为使用了变长数组

3)函数使用

示例代码:

#include <stdio.h>int sum(int r, int c, int arr[r][c]);int main(void)
{int rows = 3;int cols = 5;int i, j;int array_1[3][4] = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12}};int array_v[rows][cols];for(i = 0; i < rows; i++){for(j = 0; j < cols; j++){array_v[i][j] = i * j;}}printf("3 * 4 array:\n");printf("sum of all elements is %d\n", sum(3, 4, array_1));printf("3 * 5 VAL:\n");printf("sum of all elements is %d\n", sum(rows, cols, array_v));
}int sum(int r, int c, int arr[r][c])
{int i, j;int temp = 0;for(i = 0; i < r; i++){for(j = 0; j < c; j++){temp += arr[i][j];}}return temp;
}

运行结果:

7f8487cbc55846c3a88e2189a648d63f.png

变长数组允许动态分配存储单元,可以在程序运行时指定数组的大小

常规的C数组是静态存储分配,数组大小在编译时已经确定(因为数组大小是常量,所以编译器可以得到这些信息)

 

这篇关于再学C语言41:变长数组(VLA)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/649846

相关文章

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st