学习笔记之指针进阶(10.11)

a[0]就相当于数组名arr,a[0]+1就相当于arr+1,arr+1是数组中下一个元素的地址,所以a[0]+1就是数组中下一个元素的地址,(把二维数组中的每一个数组看作一个元素)

以上解释是错误的,a[0]不是整个数组的名字,a+1才是第二个一维数组的地址

*(a+1)和a[1]等价

sizeof内部的表达式不参与计算,所以最后一个a[3]不会报错

p+0x1和p+1有区别吗?


对于指针 p 来说,p + 0x1p + 1 实际上是没有区别的。这里的关键在于理解指针算术。

在 C 语言中,当你对一个指针进行加法操作时,编译器会根据指针所指向的数据类型来决定实际移动的字节数。如果你有一个指向某个类型的指针 p,那么 p + n 的意思是将指针向后移动 n 个该类型的元素大小。

  • 0x1 是十六进制表示的 1。
  • 1 是十进制表示的 1。

因此,p + 0x1p + 1 都是将指针 p 向后移动一个元素的大小。如果 p 指向的是一个 int 类型的数组,那么 p + 0x1p + 1 将会使指针向后移动 sizeof(int) 字节;如果 p 指向的是一个结构体,那么它们会使指针向后移动该结构体的大小(即 sizeof(struct Test))。

所以,无论你写成 p + 0x1 还是 p + 1,结果都是相同的:指针都会移动到下一个相同类型元素的位置。在这两种情况下,数值 1 都是作为元素的数量,而不是字节数来使用的。

相关推荐
生物信息与育种1 分钟前
黄三文院士领衔植物星球计划(PLANeT)发表Cell
人工智能·深度学习·算法·面试·transformer
aini_lovee7 分钟前
WSN 四大经典无需测距定位算法
算法
人道领域7 分钟前
【LeetCode刷题日记】掌握二叉树遍历:栈实现的三种绝妙方法
算法·leetcode·职场和发展
北冥湖畔的燕雀8 分钟前
深入解析Linux信号处理机制
算法
阿Y加油吧16 分钟前
二刷 LeetCode:动态规划经典双题复盘
算法·leetcode·动态规划
上弦月-编程31 分钟前
C语言指针超详细教程——从入门到精通(面向初学者)
java·数据结构·算法
莫等闲-34 分钟前
代码随想录一刷记录Day44——leetcode1143.最长公共子序列 53. 最大子序和
数据结构·c++·算法·leetcode·动态规划
生成论实验室35 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第七篇:社会与情感关系——连接、表达与共鸣
人工智能·算法·架构·交互·创业创新
承渊政道37 分钟前
【动态规划算法】(背包问题经典模型与解题套路)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
yyy(十一月限定版)1 小时前
数电1对应latex代码
算法