C 语言二级指针 内存模型图 ( 指针数组 | 二维数组 | 自定义二级指针内存 )

Posted 韩曙亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C 语言二级指针 内存模型图 ( 指针数组 | 二维数组 | 自定义二级指针内存 )相关的知识,希望对你有一定的参考价值。

前言

绘制如下 3 3 3 种二级指针的内存模型 :

// I. 指针数组
char *p1 []= "12", "ab", "34";

// II. 二维数组
char p2[3][4] = "12", "ab", "34";

// III. 自定义二维指针内存
int i = 0, num=3;
char **p3 = (char **) malloc(sizeof(char) * 3);
for(i = 0; i < num; i++)

	p[i] = (char *)malloc(sizeof (char) * 4);
	sprintf(p[i], "%d%d", i + 1, i + 1);





一、指针数组



绘制如下代码内存结构图 :

// I. 指针数组
char *p1[] = "12", "ab", "34";

指针数组 内存结构图 :

在 栈内存 中 , 是一个 指针数组 , 数组中有 3 3 3 个元素 , 都是指针数据类型 ;

指针 指向的 位置 是 全局区 的 常量区 ;





二、二维数组



绘制 二维数组 的内存模型图 :

// II. 二维数组
char p2[3][4] = "12", "ab", "34";

绘制结果如下 : 上述 二维数组 都在 栈内存中 ,

  • 每个 一维数组 都占 4 4 4 字节 ;
  • 一维数组中 , 默认值都为 ‘\\0’ 字符 ;
  • 注意 栈内存 生长方向是 从 高地址 -> 低地址 ;
  • 注意 数组 的内存方向是从 低地址 -> 高地址 , p[0] 在低地址 , p[1] 在高地址 ;
  • 全局区存在 初始化时 涉及到 的 相应字符串 常量 ;





三、自定义二维指针内存



绘制 自定义二维指针内存 的内存模型图 :

// III. 自定义二维指针内存
int i = 0, num=3;
char **p3 = (char **) malloc(sizeof(char) * 3);
for(i = 0; i < num; i++)

	p[i] = (char *)malloc(sizeof (char) * 4);
	sprintf(p[i], "%d%d", i + 1, i + 1);


绘制结果如下 : 栈内存 中 只有一个 二维指针 , 其指向的 一维指针 都在 堆内存中 , 一维指针 也是指向 堆内存 中的数据 ;

注意 指针 指向 的是 内存块的 低地址 , 不要指错了位置 ;

全局区 中的 常量区 中 , 存在初始化的 字符串 常量 数据 ;

以上是关于C 语言二级指针 内存模型图 ( 指针数组 | 二维数组 | 自定义二级指针内存 )的主要内容,如果未能解决你的问题,请参考以下文章

C语言提高内容目录

C语言 二级指针内存模型

C 语言结构体 ( 结构体中嵌套二级指针 | 为 结构体内的二级指针成员 分配内存 | 释放 结构体内的二级指针成员 内存 )

C 语言二级指针作为输入 ( 二维数组 | 二维数组内存大小计算 | 指针跳转步长问题 )

C 语言二级指针作为输入 ( 二维数组 | 二维数组遍历 | 二维数组排序 )

C 语言二级指针案例 ( 字符串切割 | 返回 自定义二级指针 作为结果 )