二级指针与指针数组搭配

目录

先明确核心前提

[用具体内存地址拆解(64 位系统)](#用具体内存地址拆解(64 位系统))

[1. 二维数组arr_1的内存布局(连续存储,每个 int 占 4 字节)](#1. 二维数组arr_1的内存布局(连续存储,每个 int 占 4 字节))

[2. 指针数组arr的内存布局(每个元素是 int*,占 8 字节)](#2. 指针数组arr的内存布局(每个元素是 int*,占 8 字节))

[3. 二级指针k的指向](#3. 二级指针k的指向)

[关键:k+1的 8 字节偏移到底偏移了什么?](#关键:k+1的 8 字节偏移到底偏移了什么?)

再看k[1][1]的完整执行过程

[对比:你以为的 "8 字节偏移" vs 实际的 "8 字节偏移"](#对比:你以为的 “8 字节偏移” vs 实际的 “8 字节偏移”)

总结


复制代码
#include<stdio.h>
int main()
{
    //指针数组与二级指针的运用
    int arr_1[2][3] = {1,2,3,4,5,6};
    int *arr[2] = {arr_1[0],arr_1[1]};
    int **k = arr;  //二级指针每次偏移8个字节
    printf("%d\n",k[1][1]);//5
    return 0;
}

分析上面的代码理解:
核心是 混淆了 "二级指针偏移的对象" 和 "二维数组元素的偏移" ------ 觉得 "偏移 8 字节是两个 int 元素"(因为 int 占 4 字节),这个结论只对 "直接偏移 int 类型" 成立,但二级指针 k的 8 字节偏移, 根本不是针对二维数组的 int 元素 ,而是针对指针数组 arr里的指针元素,我用具体的内存布局帮你彻底理清。

先明确核心前提

你的误区:把 "二级指针 k 的 8 字节偏移" 等价于 "二维数组 arr_1 的 int 元素偏移",但实际上两者偏移的是完全不同的对象。

用具体内存地址拆解(64 位系统)

我们给所有变量分配真实的内存地址,一步一步看:

1. 二维数组 arr_1****的内存布局(连续存储,每个 int 占 4 字节)
2. 指针数组 arr****的内存布局(每个元素是 int*,占 8 字节)
3. 二级指针 k****的指向

k = arr → k的值是 0x200(指向 arr 数组的首地址)。

关键: k+1****的 8 字节偏移到底偏移了什么?

你说 "偏移 8 字节只是偏移了两个元素",这个结论的问题在于: 你以为偏移的是 arr_1 里的 int 元素,但实际偏移的是 arr 里的指针元素

  • k的初始地址:0x200(指向 arr [0])
  • k+1:偏移 1 单位(8 字节)→ 地址变为 0x208(指向 arr [1])✅ 这一步偏移的是指针数组 arr 的 1 个指针元素(8 字节),不是 arr_1 的 int 元素;❌ 不是偏移 arr_1 的 2 个 int 元素(虽然 8 字节等于 2 个 int 的大小,但偏移的对象完全不同)。

再看 **k[1][1]**的完整执行过程

k[1][1]等价于 *(*(k+1)+1),拆成两步:

  1. 第一步:*(k+1) → 解引用偏移后的 k+1(地址 0x208),得到 arr [1] 的值0x10C(这是 arr_1 第二行的首地址);
  2. 第二步:*(0x10C + 1) → 这里的 "+1" 是一级指针(int*)的偏移,偏移 1 单位 = 4 字节,所以 0x10C+4=0x110,解引用得到值 5。

对比:你以为的 "8 字节偏移" vs 实际的 "8 字节偏移"

总结

  1. 偏移的对象 决定了字节数的含义:二级指针k偏移 8 字节,是偏移 1 个int*类型的指针(arr 数组的元素),而非偏移 2 个int类型的元素;
  2. k[1][1]是两次偏移:第一次是二级指针偏移(8 字节,找 arr 的第 2 个指针),第二次是一级指针偏移(4 字节,找 arr_1 第二行的第 2 个元素);
  3. 你混淆了 "指针数组的指针元素" 和 "二维数组的 int 元素",8 字节的大小巧合(等于 2 个 int)让你误以为偏移的是 int 元素,但偏移的对象才是核心。
相关推荐
iYun在学C2 小时前
驱动程序开发(字符设备驱动框架实验)
linux·c语言·嵌入式硬件
葫三生2 小时前
三生原理范畴语法表明中国哲学可为算法母语
人工智能·深度学习·算法·transformer
D_FW2 小时前
数据结构第五章:树与二叉树
数据结构·算法
WHS-_-20223 小时前
Tx and Rx IQ Imbalance Compensation for JCAS in 5G NR
javascript·算法·5g
余瑜鱼鱼鱼3 小时前
Java数据结构:从入门到精通(九)
数据结构
float_六七3 小时前
设备分配核心数据结构全解析
linux·服务器·数据结构
jinmo_C++3 小时前
Leetcode_59. 螺旋矩阵 II
算法·leetcode·矩阵
夏鹏今天学习了吗3 小时前
【LeetCode热题100(81/100)】零钱兑换
算法·leetcode·职场和发展
北京地铁1号线3 小时前
Embedding 模型的经典benchmark:MTEB
算法