C语言——指针进阶(一)

目录

​编辑

一.字符指针

[1.1 基本概念](#1.1 基本概念)

[1.2 面试题](#1.2 面试题)

二.指针数组

三.数组指针

[3.1 数组指针的定义](#3.1 数组指针的定义)

[3.2 &数组名VS数组名](#3.2 &数组名VS数组名)

[3.3 数组指针的使用](#3.3 数组指针的使用)

四.数组参数、指针参数

[4.1 一维数组传参](#4.1 一维数组传参)

​编辑

[4.2 二维数组传参](#4.2 二维数组传参)

[4.3 一级指针传参](#4.3 一级指针传参)

[4.4 二级指针传参](#4.4 二级指针传参)

​编辑

五.函数指针

六.结尾

一.字符指针

1.1 基本概念

我们可以打印试验一下字符串能否可以当成数组:

答案是可以,这样我们就学到的一种新的写法,可以直接把常量字符串存放到指针变量。

不过这么做是有弊端的,就是不能修改,当我们尝试让指向首字符a的p进行解引用(修改首个字符变为'e')会发生错误。

所以我们可以在其前面添加const,这样就不会改变报错了。

const char* p = "abcdef"

p指向的是地址,地址不能用%c来打印出来,可以用%s,而*p因为是char*的指针类型,所以解引用后只能拿到一个字符,所以要用%c打印。

1.2 面试题

我们可以发现s1与s2开辟了不同的空间指向了各自的地址。而const因为是常变量,所以当有多份的时候默认只有一份,这样s3和s4只能共同指向同一地址了,因为它是唯一的。

注意s3与s4存放的地址是一样,但是&s3和&s4可不一样,因为那是它们本身开辟用来存放地址的空间,空间地址是不一样的,只不过空间里面存放的地址(即内容)是一样的。

二.指针数组

那我们接下来可以尝试通过下标来访问数组,再通过所访问数组的下标来访问其中的元素。

三.数组指针

3.1 数组指针的定义

3.2 &数组名VS数组名

结果一样,但前2个是首个元素地址,&arr就不一定了。取arr地址用到int*,取&arr[0]用到int*,因为本质上是找到里面的元素,那么&arr又要用什么样的指针变量接收呢?

3.3 数组指针的使用

需要明确两点:1是确定好类型,2是标注大小。

我们会发现这么打印很别扭,

这样还不如指针数组方便

四.数组参数、指针参数

4.1 一维数组传参

//arr[i]-->*(arr+i)(首个元素的地址+i而不是整个元素地址+i)

4.2 二维数组传参

二维数组传参要用到数组指针,指向整个数组的地址,方便访问下一个数组地址中的元素。

p[i]-->*(p+i)解引用后实际就是数组名,后面就变成数组名[j],进行访问元素。

4.3 一级指针传参

4.4 二级指针传参

五.函数指针

我们可以发现无论是&函数名还是函数名,都是同样的地址。

函数指针的写法:

切记*pf2要用括号括起来,不然就变成了一个返回类型是Int*的函数声明了。

调用成功。

分享一段有趣的代码:

简化的版本:

六.结尾

指针进阶确实很绕,这个过程要不断地去刨析它,追根溯源。不仅仅得时常记忆,还得多去用指针,这样后续遇到关于指针类型的难题才不会被难住。

相关推荐
2013092416271 天前
1968年 Hart, Nilsson, Raphael 《最小成本路径启发式确定的形式基础》A* 算法深度研究报告
人工智能·算法
如何原谅奋力过但无声1 天前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
玄冥剑尊1 天前
贪心算法进阶
算法·贪心算法
玄冥剑尊1 天前
贪心算法深化 I
算法·贪心算法
52Hz1181 天前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
BHXDML1 天前
第一章:线性回归& 逻辑回归
算法·逻辑回归·线性回归
iAkuya1 天前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
Root_Hacker1 天前
include文件包含个人笔记及c底层调试
android·linux·服务器·c语言·笔记·安全·php
杨间1 天前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_9931 天前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode