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

指针(一):基础用法

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

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个点(n≤100),每个点的坐标均在-10000~10000之间。其中的一些点之间有连线。若有连线,则表示可从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。现...

    C++读取磁盘文件

    0.前言简单介绍一下C++读取文件的基本操作。关键技术:freopen() 文件的打开函数 FILE *fp fp=fopen(文件名,使用文件方式) 例如: fp...

    多重背包问题

    一、问题定义有 n 种物品,每种物品有三个属性:重量 weight[i](正整数)价值 value[i](正整数)数量 count[i](正整数,表示...

    NOIP2013年普及组初赛题目及答案分析

    NOIP2013年普及组初赛题目及答案分析

    一、单项选择题1. 一个 32 位整型变量占用( A )个字节。 A. 4    B. 8      C. 32     &nbs...

    2023 CSP 山东地区分数线汇总

    地区CSP-XCSP-JCSP-S烟台556648.5临沂516416青岛476753淄博446547.5...

    树的遍历

    在应用树结构解决问题时,往往要求按照某种此项获得树中全部结点的信息,这种操作叫做树的遍历。遍历的方法有很多种。常用的有:A. 先序遍历:先访问根结点,再从左到右按照先序思想遍历各子树。B. 后序遍历:...