参考链接:https://blog.csdn.net/soonfly/article/details/51131141
指针是一个特殊的变量,它里面存储的数值被解释成为内存里的一个地址。
一、指针定义
复杂指针定义涉及较多运算符,分析指针功能从变量名处起,根据运算符优先级结合,一步一步分析。首先根据变量最先进行运算的远算符确定该变量是指针,还是该变量存储的数据类型、返回值是指针。如果该变量是指针,只要把指针声明语句中的指针名字和名字左边的指针声明符*去掉,剩下的就是指针所指向的类型。
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类型,所以p是一个有一个整型参数返回值为整型数据的指针的函数int (*p)(int); //从P 处开始,先与指针结合,说明P 是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型的参数,再与最外层的int 结合,说明函数的返回类型是整型,所以P 是一个指向有一个整型参数且返回类型为整型的函数的指针
二.指针的算术运算
使用*获得指针所指地址存放数据,注意和定义时使用*区分,定义时使用*只是表明p是一个指针元素,左侧表示该指针元素所指向地址。使用&获取元素首地址(返回数据类型是一个指向该变量数据类型的指针)。
char sh='a';//定义char类型变量sh并赋值为'a'char *p=&sh;//定义char类型指针,并指向sh变量cout<<*p;//获得指针p所指对象内容,输出a
指针可以加上或减去一个整数。指针的这种运算的意义和通常的数值的加减运算的意义是不一样的。每+1意味着指针所指地址,移动到下一个该类型元素。例如int *每次加1,意味着实际指向内存地址加4(int类型数据占4个字节),double*每次加1,意味着实际指向内存地址加8(double类型数据占8个字节)。
int array[5] = { 1,2,3 };//声明大小为5的整数数组array,初始化前三个元素,后面两个元素默认为0int* ptr = array;//定义int类型指针,赋值为array(数组名本身也可以看作一个指针)for (int i = 0; i < 5; i++){(*ptr)++;//指针所指向元素+1ptr++;//指针+1(指向下一个该指针元素地址),int类型指针所指元素占4个字节,所以当前指针指向4个字节后的地址,即指向array第二个元素cout << array[i] << ' ';//依次输出2 3 4 1 1}
三.指针和结构体的关系
通过结构体指针访问结构体成员变量
1.通过->运算符
2.先通过*运算获得指针所指内容(此处为结构体ss),再通过.运算获得,注意加小括号(.运算优先级高于*)
struct MyStruct{int a;int b;int c;};struct MyStruct ss = { 20,30,40 };//声明了结构对象ss,并把ss 的成员初始化为20,30 和40。struct MyStruct* ptr = &ss;//通过指针访问结构体元素cout <a <运算符cout << (*ptr).b << endl;//2.先通过*运算获得指针所指内容(此处为结构体ss),再通过.运算获得,注意加小括号(.运算优先级高于*)