一、概念
在如下的A指向B、B指向C的指向关系中:
首先
C是"一段内容",比如你用malloc或者new分配了一块内存,然后塞进去"一段内容",那就是C了。C的起始地址是 0x00000008。
B是一个指针变量,其中存放着C的地址,但是B也要占空间的啊,所以B也有地址,B的起始地址是 0x00000004,但是B内存中存放的是C的地址,所以B里面的内容就是 0x00000008。
那么到此为止都比较好理解:
B= 0x00000008; //B的内容
*B = "一段内容"; //B解引用,也就是B指针指向的C的值
&B = 0x00000004; //B取地址,B的地址是0x00000004
那么,再来看A:
A是二级指针变量,其中存放着B的地址 0x00000004,A也有地址,是 0x00000000;
*A = B= 0x00000008; //A解引用也就是B的内容
**A = *B = "一段内容"; //B解引用,也就是B指针指向的C的值
A = &B = 0x00000004; //A存的是B的地址,B的地址是0x00000004
&A = 0x00000000; //A取地址
二、使用
二级指针作为函数参数的作用:在函数外部定义一个指针p,在函数内给指针赋值,函数结束后对指针p生效,那么我们就需要二级指针。
看看下面一段代码:有两个变量a,b,指针q,q指向a,我们想让q指向b,在函数里面实现。
1.先看看一级指针的实现#include
using namespace std;
int a= 10;
int b = 100;
int *q;
void func(int *p)
{
cout
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?