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

指针(一):基础用法

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

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;
}



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

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

分享给朋友:

相关文章

NOIP/CSP-J复赛历年考点

2000计算器的改良税收与补贴乘积最大单词接龙模拟、字符串模拟字符串、动态规划广度优先bfs、字符串2001数的计数最大公约数与最小公倍数求先序排列装箱问题模拟模拟、函数二叉树贪心2002级数求和选数...

树的存储结构

【方法1:数组】称为父亲表示法const int m=10;          ...

【算法】扩展欧几里得算法

一、欧几里得算法我们前面学过求最大公约数的算法:欧几里得算法(又叫辗转相除法) ,一般缩写是gcd,在C++中经常写成如下形式:int gcd(int a,int b)...

STL入门——容器1:vector (不定长度数组)

一、定义     vector是一个不定长度数组。不仅如此,它把一些常用操作“封装”在了 vector 类型内部。    ...

如何判断回文数/回文串

所谓回文,就是从左往右读和从右往左读都是一样的,这样的数字或者字符称为回文数/回文字符。做题的时候经常能看到判断回文操作。判断回文的一般有两种,一种是数字类型,一种是字符类型。两种分别介绍一下。一、回...

【算法】单链表的一些操作(存取、查找、取出、插入、删除)

一、单链表结构的建立与输出#include<iostream> using namespace std; struct Node{ int ...