一、指针概念:
指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址。
二、指针的定义:
int p = 5 ; //定义一个整形变量,存的值是5
int *p = &a; //定义一个int类型的指针p,存的是a的地址
很明显指针的定义和普通的整形定义有所不同,他们的区别就可以简单概括为:
- 指针类型 赋值号的左边有一个 * ,这个 * 表示的就是p是一个指针
- 指针类型 赋值号的右边有一个 & ,这个 & 表示的就是取a的地址
以此类推,我们还可以定义各种各样的指针,例如:
float *p = &b; //定义一个float类型的指针p,存的是b的地址
char *p = &c; //定义一个char 类型的指针p,存的是c的地址
三、指针的应用
举几个指针常见应用的例子
p = &d //把 d 的地址赋值给p(也就是我们常说的 p 指向 d)
E = *p //取p变量所指向的值(注意这块儿是取值,而非定义,这个和定义一样都用的 * 号 , 但是定义的时候前面有类型)
写简单的代码应用一下:
#include <stdio.h>
int a = 10;
int main(){
int *p = &a; //定义一个指针p,存的是a的地址
printf("p= %d\n",p); //输出p的值测试一下
printf("*p= %d\n",*p);//输出*p的值
*p = *p +1;
printf("a= %d\n",a); //对*p操作后a的结果如何?
return 0;
}
测试结果:
四、指针的高级应用(小白勿看)
- int p; //这是一个普通的整型变量
- int * p; //首先从P 处开始,先与*结合,所以说明P 是一个指针,然后再与int结合,说明指针所指向的内容的类型为int 型.所以P是一个返回整型数据的指针
- int p[3]; //首先从P处开始,先与[]结合,说明P 是一个数组,然后与int 结合,说明数组里的元素是整型的,所以P 是一个由整型数据组成的数组
- int * p[3]; //首先从P 处开始,先与[]结合,因为其优先级比高,所以P 是一个数组,然后再与结合,说明数组里的元素是指针类型,然后再与int 结合,说明指针所指向的内容的类型是整型的,所以P是一个由返回整型数据的指针所组成的数组
- int (* p)[3]; //首先从P 处开始,先与*结合,说明P是一个指针然后再与[]结合(与"()"这步可以忽略,只是为了改变优先级),说明指针所指向的内容是一个数组,然后再与int结合,说明数组里的元素是整型的.所以P 是一个指向由整型数据组成的数组的指针
- int **p; //首先从P开始,先与结合,说是P 是一个指针,然后再与结合,说明指针所指向的元素是指针,然后再与int 结合,说明该指针所指向的元素是整型数据.由于二级指针以及更高级的指针极少用在复杂的类型中,所以后面更复杂的类型我们就不考虑多级指针了,最多只考虑一级指针.
- int p(int); //从P 处起,先与()结合,说明P是一个函数,然后进入()里分析,说明该函数有一个整型变量的参数,然后再与外面的int 结合,说明函数的返回值是一个整型数据
- Int (* p)(int); //从P 处开始,先与指针结合,说明P是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型的参数,再与最外层的int结合,说明函数的返回类型是整型,所以P 是一个指向有一个整型参数且返回类型为整型的函数的指针
- int * (* p(int))[3]; //可以先跳过,不看这个类型,过于复杂从P 开始,先与()结合,说明P 是一个函数,然后进入()里面,与int结合,说明函数有一个整型变量参数,然后再与外面的结合,说明函数返回的是一个指针,然后到最外面一层,先与[]结合,说明返回的指针指向的是一个数组,然后再与结合,说明数组里的元素是指针,然后再与int 结合,说明指针指向的内容是整型数据.所以P 是一个参数为一个整数据且返回一个指向由整型指针变量组成的数组的指针变量的函数.
五、指针的装逼应用(太高级了估计没人看,慢慢写,先插眼)
………………