C语言一级指针二级指针和三级指针区别及使用详解

 更新时间:2023年05月19日 10:27:47   作者:前端跑起来  
这篇文章主要为大家介绍了C语言一级指针二级指针和三级指针,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

1.一级指针

#include <stdio.h>
int main(){
 int data = 10;
 int *p1 = &data; // p1 = &data
 printf("data的地址是:%p\n", &data);
 printf("p1指针变量地址是:%d,内容是%d\n", p1, *p1);
 // 通过指针修改变量值
 printf("\n");
 *p1 = 20;
 printf("data=%d, *p1=%d\n", data, *p1);
 return 0;
}

运行结果如下:

data的地址是:00AFFB18

p保存的data的地址是:11533080,内容是10

data=20, *p1=20

一级指针的用法其实是取数据的地址,以此类推,二级指针就是取一级指针的地址,也可以表示一级指针的指向的内容。

2.二级指针

指针变量也是一种变量,也会占用存储空间,也可以使用&获取它的地址。C语言不限制指针的级数,每增加一级指针,在定义指针变量时就得增加一个星号*。p1是一级指针,指向普通类型的数据,定义时只有一个*;p2是二级指针,指向一级指针p1,定义时需要两个*。

它们关系如下所示:

上图关系所示:data是int类型变量,p1是指向data的指针变量,p2又是指向p1的指针变量。

假设a、p1、p2、p3的地址分别为0x00A0、0x0010、0x0020、0x0030。它们之间的关系可以用下图描述:

根据上图描述的逻辑,代码表示如下:

#include <stdio.h>
int main(){
 int data = 10;
 int *p1 = &data;
 int **p2 = &p1;
 printf("%d, %d, %d\n", data, *p1, **p2);
 printf("&p1=%#X, p2=%#X\n", &p1, p2); // p1的地址为p2的值
 printf("&data=%#X, p1=%#X\n", &data, p1); // data的地址为p1的值
 return 0;
}

运行结果如下所示:

10, 10, 10

&p1=0X12FFE94, p2=0X12FFE94

&data=0X12FFEA0, p1=0X12FFEA0

**p2等价于(*(*p2)),

3.三级指针

以此类推,一级指针加一个*,二级指针增加两个*,三级指针增加三个*。

我们可以先用图去梳理指针之间的关系:

假设a、p1、p2、p3的地址分别为0x00A0、0x0010、0x0020、0x0030。它们之间的关系可以用下图描述:

根据上图描述的逻辑,代码表示如下:

#include <stdio.h>
int main(){
 int a = 100;
 int *p1 = &a;
 int **p2 = &p1;
 int ***p3 = &p2;
 printf("%d, %d, %d, %d\n", a, *p1, **p2, ***p3);
 printf("&p2 = %#X, p3 = %#X\n", &p2, p3);
 printf("&p1 = %#X, p2 = %#X, *p3 = %#X\n", &p1, p2, *p3);
 printf(" &a = %#X, p1 = %#X, *p2 = %#X, **p3 = %#X\n", &a, p1, *p2, **p3);
 return 0;
}

100, 100, 100, 100

&p2 = 0XC2FB7C, p3 = 0XC2FB7C

&p1 = 0XC2FB88, p2 = 0XC2FB88, *p3 = 0XC2FB88

&a = 0XC2FB94, p1 = 0XC2FB94, *p2 = 0XC2FB94, **p3 = 0XC2FB94

以三级指针 p3 为例来分析上面的代码。***p3等价于*(*(*p3))。*p3 得到的是 p2 的值,也即 p1 的地址;*(*p3) 得到的是 p1 的值,也即 a 的地址;经过三次操作后,*(*(*p3)) 得到的是 a 的值。

以上就是C语言一级指针二级指针和三级指针区别及使用详解的详细内容,更多关于C语言一级二级三级指针的资料请关注脚本之家其它相关文章!

相关文章

  • c++中为什么不提倡使用vector示例详解

    c++中为什么不提倡使用vector示例详解

    这篇文章主要给大家介绍了关于c++中为什么不提倡使用vector的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用c++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • C++中std::invalid_argument报错解决

    C++中std::invalid_argument报错解决

    在C++编程中,std::invalid_argument是一个常见的异常,用于指示函数参数无效,文章详细解析了这一异常的产生原因,并提供了多种解决策略,感兴趣的可以了解一下
    2024-09-09
  • c++ 探讨奶牛生子的问题

    c++ 探讨奶牛生子的问题

    一只刚出生的奶牛,第4年开始生一只奶牛(假设只生母牛),以后每年生一只。现在给你一只刚出生的奶牛,求20年后有多少奶牛
    2013-05-05
  • C++实现多线程查找文件实例

    C++实现多线程查找文件实例

    这篇文章主要介绍了C++实现多线程查找文件实例,对于深入学习C++程序设计有着很好的参考借鉴价值,需要的朋友可以参考下
    2014-10-10
  • C语言中结构体和共用体实例教程

    C语言中结构体和共用体实例教程

    这篇文章主要给大家介绍了关于C语言中结构体和共用体的相关资料,结构体是一种自定义的复合数据类型,共用体也叫联合体,使几个不同类型的变量共占一段内存(相互覆盖),需要的朋友可以参考下
    2021-06-06
  • C++ 基本数据类型中int、long等整数类型取值范围及原理分析

    C++ 基本数据类型中int、long等整数类型取值范围及原理分析

    这篇文章主要介绍了C++ 基本数据类型中int、long等整数类型取值范围及原理分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++泛型算法的一些总结

    C++泛型算法的一些总结

    以下是对C++中的泛型算法进行了总结介绍。需要的朋友可以过来参考下
    2013-08-08
  • C++实现LeetCode(102.二叉树层序遍历)

    C++实现LeetCode(102.二叉树层序遍历)

    这篇文章主要介绍了C++实现LeetCode(102.二叉树层序遍历),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++哈希表之线性探测法实现详解

    C++哈希表之线性探测法实现详解

    线性探测法的优点:只要散列表未满,总能找到一个不冲突的散列地址;缺点:每个产生冲突的记录被散列到离冲突最近的空地址上,从而又增加了更多的冲突机会
    2022-05-05
  • C++ 常量成员常量返回值详解

    C++ 常量成员常量返回值详解

    这篇文章主要介绍了C++ 常量成员常量返回值详解,需要的朋友可以参考下
    2017-06-06

最新评论