二级指针与指针数组搭配

目录

先明确核心前提

[用具体内存地址拆解(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 元素,但偏移的对象才是核心。
相关推荐
那个村的李富贵36 分钟前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿44 分钟前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码1 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
熬夜有啥好1 小时前
数据结构——哈希表
数据结构·散列表
琹箐1 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia12 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了2 小时前
数据结构之树(Java实现)
java·算法
算法备案代理2 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.2 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
我能坚持多久3 小时前
【初阶数据结构01】——顺序表专题
数据结构