指针
指针是存放地址的变量
#include <stdio.h>
int main()
{
int i = 1; //在内存中开辟一片空间
int *p = &i; //将i的地址存放在变量p中,p就是一个指针变量
return 0;
}
二级指针
指针变量也是变量,是变量就有地址,所以存放指针变量的地址,就是二级指针。如下:a的地址存放在pa中,pa的地址存放在ppa中。pa是一级指针,ppa是二级指针。
int a = 1;
int* pa =&a;
int** ppa = &pa;
指针数组
指针数组:首先它是一个数组,数组的元素都是指针,数组占多少个字节由数组本身决定。是存放指针的数组。如arr1是一个数组,有五个元素,每个元素是一个整形指针。
数组指针
数组指针:首先它是一个指针,它指向一个数组。在 32 位系统下永远是占 4 个字节,至于它指向的数组占多少字节,不知道。它是“指向数组的指针”的简称。
指针数组和数组指针的理解
例,下面到底哪个是数组指针,哪个是指针数组呢?
A)int *p1[5];
B)int(*p2)[5];
这里有一个符号之间的优先级问题。“[]”的优先级比“ * ”要高。p1 先与“[]”结合,构成一个数组,数组名为 p1,int * 修饰的是数组的内容,即数组的每个元素。因此,p1是一个存放了 5个指向 int 类型数据的指针,即指针数组。
p2 中“()”的优先级比“[]”高,“*”号和 p2 构成一个指针,指针变量名为 p2,int 修饰的是数组的内容,即数组的每个元素。数组在这里并没有名字,是个匿名数组。因此, p2 指向一个包含 5 个 int 类型数据的数组,即数组指针。