C语言进阶指南(11)(指针数组与二维数组)

*欢迎来到博主的专栏------C语言进阶指南

博主id:reverie_ly

文章目录

N级指针

指针变量是一个存放地址的变量,在C语言中,每个变量都会有一个地址值。所以指针变量也有一个地址。

c 复制代码
int main()
{
	int a = 0;
	int* pi = &a;//pi变量的值是a的地址
	int** ppi = π//ppi的值是pi的地址
}

从vs调试的监视窗口可以看到
pi的类型是int*,存储的是int类型的a的地址。 pi是一级指针
ppi的类型是int**,存储的是int*类型的pi的地址。 ppi是二级指针.

将存储数据变量地址的指针称为1级指针,存储一级指针地址的指针称为2级指针,以此类推。N级指针存储的是N-1级指针的地址。

指针数组

声明指针数组的标准形式如下

type *name[];

name是标识符,指针数组的声明是先让标识符与数组声明符([])结合,使这个声明是一个数组,然后在声明指针(*),声明这个数组是一个指针的数组。type是指针指向的变量的类型。

以一个指针数组的声明为例

c 复制代码
	int a, b, c, d, e;
	int* parr[5] = { &a,&b,&c,&d,&e };

该数组parr是一个 5个元素 都是 指针 的 数组。 分别指向a,b,c,d,e这五个变量。此时可以通过解引用数组的元素来操作这些变量

c 复制代码
	int a, b, c, d, e;
	int* parr[5] = { &a,&b,&c,&d,&e };

	*parr[0] = 1;//a=1
	*parr[1] = 2;//b=2
	*parr[2] = 3;//c=3
	*parr[3] = 4;//d=4
	*parr[4] = 5;//e=5

指针数组与二维数组

在数组和指针这一章里我们了解到数组名和指针之间的关系。当数组名作为指针使用时,
指针的值是数组的首元素的地址。

而二维数组的行下标指向的是一维数组的地址。以arr[2][5]为例

我们可以发现:

指针数组可以充当二维数组的行下标

因为他们都有着类似的作用,即指向一个数组的地址。

c 复制代码
	int arr[2][5] = { 0 };
	int* parr[2] = { arr[0],arr[1] };
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 5; j++)
		{
			parr[i][j] = j;
		}
	}
	return 0;

在该程序中,我们将arr[0]和arr[1]作为指针数组的元素,当对parr进行元素访问操作时,可以得到arr[0]或arr[1]的地址。再对元素进行访问操作,就能得到二维数组中的元素。

数组指针作为函数的参数

可以将指针数组作为函数原型的参数来对二维数组进行操作。

c 复制代码
void  print(int* parr[])
{
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 5; j++)
		{
			printf("%d ", parr[i][j]);
		}
		printf("\n");
	}
}

如果将上面例子结合起来,正确的传参形式是

print(parr);

在C语言进阶指南(10)中我们提到了,数组名在作为指针操作时会发生的类型降级的例子。所以上述函数在设计原型时也可以设计为

c 复制代码
void  print(int** parr)
{
	for (int i = 0; i < 2; i++)
	{
		for (int j = 0; j < 5; j++)
		{
			printf("%d ", parr[i][j]);
		}
		printf("\n");
	}
}

相关文章传送门:
C语言进阶指南(10)(指针与数组)

相关推荐
wefly20174 分钟前
纯前端架构深度解析:jsontop.cn,JSON 格式化与全栈开发效率平台
java·前端·python·架构·正则表达式·json·php
nbwenren44 分钟前
node.js内置模块之---crypto 模块
java
三道渊1 小时前
C语言:文件I/O
c语言·开发语言·数据结构·c++
weyyhdke2 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
kali-Myon2 小时前
CTFshow-Pwn142-Off-by-One(堆块重叠)
c语言·数据结构·安全·gdb·pwn·ctf·
潇冉沐晴2 小时前
DP——背包DP
算法·背包dp
chools2 小时前
Java后端拥抱AI开发之个人学习路线 - - Spring AI【第一期】
java·人工智能·学习·spring·ai
逆境不可逃3 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾3 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
jeCA EURG3 小时前
Spring Boot 2.7.x 至 2.7.18 及更旧的版本,漏洞说明
java·spring boot·后端