malloc() 函数在 C 语言编程中用于将数据存储在堆中,堆是动态内存存储。多用于数组的动态声明,也可用于二维数组的创建。二维数组用于绘制具有列和行的表格形式的值。
在这篇文章中,我们将学习在 C 语言编程中使用 malloc() 函数创建一个二维数组。
什么是 C 语言编程中的 malloc() 函数
在一些特定的程序中,我们常常无法预测数组的大小。如果我们自己将值分配给数组,那么它在执行期间无法更改。这会产生问题,要么数组的内存变低,要么数组占用更少的空间浪费内存,因此为避免这种情况,建议动态分配数组。
在 C 语言编程中,对于动态内存分配,使用了不同的函数。其中之一是 malloc() 函数;它向堆发送特定内存块的请求,如果堆有空间,它通过将请求的内存块分配给 malloc() 来响应。
malloc() 会根据执行程序的需要占用分配的内存块空间,执行成功后,可以使用 free() 函数释放该空间。
如何在 C 语言编程中使用 malloc() 函数创建二维数组
在创建之前,请考虑下图以更好地理解二维数组的工作原理。
上图中,我们可以理解,在一个二维数组中,先将元素固定在对应的行被填充后的列的第一个框中,然后是列的第二行,一直到整个数组被填充,就像第一个元素将被放置在 x[0][0],然后是 x[0][1],然后是 [0][2],然后是 x[0][1],[1][ 0],以此类推。
我们将考虑以下在 C 编程中使用 malloc() 创建二维数组的基本示例。我们创建了一个文本文件 linuxmi.c 并在其中键入以下脚本:
#include <stdio.h>
#include <stdlib.h>
int main() {
int row = 5, col = 4;
int *a = (int *)malloc(row * col * sizeof(int));
int i, j;
for (i = 0; i < row; i++)
for (j = 0; j < col; j++)
*(a + i*col + j) = i + j;
printf("数组元素是:\n");
for (i = 0; i < row; i++) {
for (j = 0; j < col; j++) {
printf("%d ", *(a + i*col + j));
}
printf("\n");
}
free(a);
return 0;
}
要编译上述程序,我们将使用 GCC 编译器:
linuxmi@linuxmi:~/www.linuxmi.com$ gcc linuxmi.c -o linuxmi
执行linuxmi,这是linuxmi.c的编译文件,显示输出:
nuxmi@linuxmi:~/www.linuxmi.com$ ./linuxmi
如下图:
在上面的代码中,我们已经包含了 stdlib.h(用于动态内存分配)和 stdio.h(用于输入和输出)的库,然后我们声明了变量 row、column、i 和 j。声明后,我们调用 malloc() 根据“行”和“列”的值分配内存。分配内存后,我们只需使用两个嵌套循环将值保存在数组中,然后在嵌套循环中使用 printf() 显示值。最后,我们使用free()清空了malloc()在堆上分配的占用空间。
结论
二维数组与一维数组类似,一维数组和二维数组的唯一区别是;二维数组以表格形式存储数据,一维数组以行的形式存储数据。数组是数据结构的基础,它们可以存储大量相同数据类型的数据。在本文中,我们通过调用 malloc() 函数解释了在动态内存中创建二维数组。