当前位置:首页 > C++目录 > 正文内容

指针(一):基础用法

亿万年的星光5年前 (2021-08-08)C++目录2993

1.定义

什么是指针,简单来说:“指针就是地址”。


2.指针变量的定义

指针变量定义形式:  类型说明符  *变量名

其中,*号表示指针变量。变量名即为定义的指针变量名,类型说明符表示该指针变量所指向的变量的数据类型。

普通变量:int a=5;

解释:定义了变量a,是int型的,值为5。内存中有一块内存空间是放a的值。对a的存取操作就是直接到这个内存空间存取。内存空间的位置叫地址,存放5的地址可以用取地址操作。用“&”符号运算得到。即&a;

指针变量:int *p=NULL;

解释:定义了一个指针变量p,p指向一个内存空间,里面存放的是一个内存地址。现在赋值为null(其实就是0,表示特殊的空地址)

比较通俗一点的解释,对于普通变量来说,a是一个int型变量,a的值的5。p是一个int *型变量,p的值是null。

3.指针变量的赋值与操作


#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a=3;
	int *p=NULL;
	cout<<"a的值"<<a<<endl;  //3
	cout<<"p的值"<<p<<endl;  //0
	cout<<"*p的值"<<*p<<endl; //程序报错 
	return 0;
}


将指针变量指向一个地址后:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a=3;
	int *p=NULL;
	p=&a;
	cout<<"a的值"<<a<<endl;  //3
	cout<<"p的值"<<p<<endl;  //0x22fe34 
	cout<<"*p的值"<<*p<<endl; //3
	return 0;
}

可以看到p这个变量(int *类型)存储的是地址变量,不是普通的数值变量,所以p本身也是一个变量只不过存储的是地址而已。

将指针变量赋值后:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a=3;
	int *p=&a;
	cout<<"a的值"<<a<<endl;  //3
	cout<<"p的值"<<p<<endl;  //0x22fe34 
	cout<<"*p的值"<<*p<<endl; //3
	*p=6;
	cout<<"a的值"<<a<<endl;  //6
	cout<<"p的值"<<p<<endl;  //0x22fe34 
	cout<<"*p的值"<<*p<<endl; //6
	return 0;
}

将指针变量指向一个新地址后:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a=3;
	int *p=NULL;
	p=&a;
	cout<<"a的值"<<a<<endl;  //3
	cout<<"p的值"<<p<<endl;  //0x22fe34 
	cout<<"*p的值"<<*p<<endl; //3
	int b=10;
   	p=&b;
	cout<<"a的值"<<a<<endl;  //3
	cout<<"b的值"<<b<<endl; //10 
	cout<<"p的值"<<p<<endl;  //0x22fe00
	cout<<"*p的值"<<*p<<endl; //10
	return 0;
}



扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

【题解】围圈报数(约瑟夫问题)

【题解】围圈报数(约瑟夫问题)

【题目描述】有n个人依次围成一圈,从第1个人开始报数,数到第m个人出列,然后从出列的下一个人开始报数,数到第m个热呢又出列,... ,如此反复到所有的人全部出列为止。设n个人的编号分别为1,2,......

【C++图形化编程】鼠标函数及鼠标画板

【C++图形化编程】鼠标函数及鼠标画板

0.前言这篇文章简单介绍一下利用鼠标画图的程序#include<graphics.h> #include<conio.h> int main(){ initg...

【数论】二项式定理

【数论】二项式定理

一、基本概念上面这个式子就叫做二项式定理,又称牛顿二项式定理,该定理给出两个数之和的整数次幂诸如展开为类似项之和的恒等式。二项式定理可以推广到任意实数次幂,即广义二项式定理。 初中高中阶段比...

【图】并查集—优化

【图】并查集—优化

上一篇文章,简单介绍了并查集。这篇文章,介绍一下并查集的改进以及优化。find函数的优化(路径压缩)因为并查集的merge操作:void merge(int a, int...

【数据结构】栈—括号匹配检验

【数据结构】栈—括号匹配检验

【题目描述】假设表达式中允许包含两种括号:圆括号和方括号,其嵌套的顺序随意,如([ ]())或[  (  [  ] [  ] ) ] 等为正确的匹配,[&nbs...

组合数的写法

前面我们写过 全排列和排列数 等。这篇文章。我们写一下组合数。例题:从n个数中,选出m个,一共有多少种不同的选法?这是一道典型的组合数公式。我们直接用dfs公式肯定会出现重复的。#include<...