C语言使用malloc函数模拟开辟二维数组(带分析)

系列文章目录

🌟 个人主页古德猫宁-

🌈 信念如阳光,照亮前行的每一步


文章目录

  • 系列文章目录
    • [🌈 *信念如阳光,照亮前行的每一步*](#🌈 信念如阳光,照亮前行的每一步)

当我们使用malloc函数来模拟创建一个二维数组时,我们需要理解二维数组在内存中是如何存储的。在C语言中,二维数组实际上是一维数组的数组。也就是说,一个二维数组可以被看作是一个包含多个一维数组的数组
考虑一个row行、cols列的二维整数数组。在内存中,它被表示为一系列相邻的整数存储单元。对于一个int**类型的指针数组,首先我们需要分配内存以存储行指针,然后为每一行分配内存以存储列的元素。

c 复制代码
#include<stdio.h>
#include<stdlib.h>
int main()
{
	int row = 3;
	int cols = 4;//确定要申请多大的二维数组
	//申请一个存储指针的数组,该数组的每一个元素都是指向整数的指针,二级指针
	int** arr = (int**)malloc(row * sizeof(int*));
	
	//这里需要判断一下分配是否成功
	if (arr == NULL)
	{
		perror("malloc");
		return 1;
	}
	
	//使用malloc为每行的每一列分配内存
	int i;
	int j;
	for (i = 0;i < row;i++)
	{
		arr[i] = (int*)malloc(cols * sizeof(int));
	}
	
	//判断
	if (arr[i] == NULL)
	{
		perror("malloc");
		return 1;
	}
	
	//访问赋值
	for (i = 0;i < row;i++)
	{
		for (j = 0;j < cols;j++)
		{
			arr[i][j] = i * cols;//这里谁便赋的值
		}
	}
	
	//打印
	for (i = 0;i < row;i++)
	{
		for (j = 0;j < cols;j++)
		{
			printf("%d", arr[i][j]);
		}
	}
	//首先释放每一行的内存,然后释放行指针数组的内存
	for (i = 0;i < row;i++)
	{
		free(arr[i]);
	}
	free(arr);
	return 0;
}

注意:这个方法只是模拟了二维数组的行为,实际上它在内存中是一维数组

相关推荐
superior tigre3 分钟前
C++学习:六个月从基础到就业——C++11/14:列表初始化
c++·学习
阿图灵17 分钟前
文章记单词 | 第93篇(六级)
学习·学习方法
superior tigre21 分钟前
C++学习:六个月从基础到就业——C++11/14:decltype关键字
c++·学习
技术流浪者24 分钟前
C/C++实践(十)C语言冒泡排序深度解析:发展历史、技术方法与应用场景
c语言·数据结构·c++·算法·排序算法
麟城Lincoln38 分钟前
【Linux笔记】nfs网络文件系统与autofs(nfsdata、autofs、autofs.conf、auto.master)
linux·网络·笔记·nfs·autofs
I AM_SUN1 小时前
98. 验证二叉搜索树
数据结构·c++·算法·leetcode
fengye2071611 小时前
板凳-------Mysql cookbook学习 (二)
学习·mysql·adb
Cloud Traveler1 小时前
迁移学习:解锁AI高效学习与泛化能力的密钥
人工智能·学习·迁移学习
学习中的码虫1 小时前
数据结构基础排序算法
数据结构·算法·排序算法
星川皆无恙1 小时前
大模型学习:Deepseek+dify零成本部署本地运行实用教程(超级详细!建议收藏)
大数据·人工智能·学习·语言模型·架构