指针初阶(2)

文章目录

    • [5. 指针和数组](#5. 指针和数组)
    • [6. 二级指针](#6. 二级指针)
    • [7. 指针数组](#7. 指针数组)
  • 附:

5. 指针和数组

指针变量:指针变量就是指针变量,不是数组,指针变量的大小是4/8个字节,专门是用来存放地址的。
数组:数组就是数组,不是指针,数组是一块连续的空间,可以存放1个或者多个类型相同的数据。

两者之间的联系:

数组中,数组名其实是数组首元素的地址,数组名 == 地址 == 指针

当我们知道数组首元素的地址的时候,因为数组又是连续存放的,所以通过指针就可以遍历访问数组

数组是可以通过指针来访问的

c 复制代码
#include <stdio.h>

int main()
{
	int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	int* p = arr;

	for (i = 0; i < sz; i++)
	{
		//printf("%p == %p\n", p + i, &arr[i]);
		printf("%d ", *(p + i));
	}

	return 0;
}

6. 二级指针

指针变量也是变量,是变量就有地址,那指针变量的地址存放在哪里?

这就是二级指针。

c 复制代码
#include <stdio.h>

int main()
{
	int a = 10;
	int* p = &a;//p是一级指针变量,指针变量也是变量,变量是在内存中开辟空间的,是变量就有地址
	int** pp = &p;//pp就是二级指针变量,二级指针变量就是用来存放一级指针变量的地址
	
	//*(*pp) = 100;
	**pp = 100;
	printf("%d\n", a);

	//int** * ppp = &pp;

	return 0;
}

举个例子:

c 复制代码
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "hello world";
	char arr3[] = "cuihua";

	char* parr[] = { arr1, arr2, arr3 };

	char** p = parr;

	return 0;
}

7. 指针数组

指针数组是指针还是数组?

答案:是数组,是存放指针的数组。

数组我们已经知道整形数组,字符数组,那指针数组是怎样的?

c 复制代码
#include <stdio.h>

int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "hello world";
	char arr3[] = "cuihua";

	//指针数组
	char* parr[] = { arr1, arr2, arr3 };
	int i = 0;

	for (i = 0; i < 3; i++)
	{
		printf("%s\n", parr[i]);
	}


	/*char arr[] = "abcdef";
	printf("%s\n", arr);*/

	return 0;
}
c 复制代码
#include <stdio.h>

int main()
{
	int arr1[] = { 1, 2, 3, 4, 5 };
	int arr2[] = { 2, 3, 4, 5, 6 };
	int arr3[] = { 3, 4, 5, 6, 7 };

	//指针数组
	int* parr[] = { arr1, arr2, arr3 };
	
	int i = 0;

	for (i = 0; i < 3; i++)
	{
		int j = 0;

		for (j = 0; j < 5; j++)
		{
			printf("%d ", parr[i][j]);
			//printf("%d ", *(parr[i] + j));//和上面等价
		}

		printf("\n");
	}

	return 0;
}

附:

指针初阶(1)

相关推荐
BothSavage8 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn9 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽10 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法