知识点
int s=10;
int* p=&s;
*p++;//这个代表的是将p这个地址++,这个操作之后已经不能再使用*p来取s的值了
(*p)++;//这个代表的才是将s的值++,
运算符的优先级
数组与指针
如果使用指针来操作数组中的元素的话,效率是很高的,因为是直接使用地址来访问的
一点疑惑
printf("%ld \n",sizeof(int*));
printf("%ld \n",sizeof(long*));
8
8
既然int类型的指针和long类型的指针占用的大小都一样,那么在定义指针类型的变量的时候为什么还用区分这个指针类型是int类型的指针、float类型的指针还是long类型的指针呢?
其实这是为了指针的运算,比如说对int类型的指针进行+1操作和对long类型的指针进行+1操作得到的结果并不一样。
数组指针与指针数组
数组指针(也称行指针)
定义 int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]
所以数组指针也称指向一维数组的指针,亦称行指针。
指针数组
定义 int *p[n];
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素,这样赋值是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样 *p=a; 这里*p表示指针数组第一个元素的值,a的首地址的值。
如要将二维数组赋给一指针数组:
int *p[3];
int a[3][4];
p++; //该语句表示p数组指向下一个数组元素。注:此数组每一个元素都是一个指针
for(i=0;i<3;i++)
p[i]=a[i]
这里int *p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2]
所以要分别赋值。
一点疑惑
比如说定义int (*p)[n],那么p就是指向一个长度是n的一维数组,那么这个是什么呢?
int aa[5]={1,2,3,4,5};
int *p2=aa;
这个p2是不是也可以说是指向了一个长度为5的一维数组,但是它不是数组指针啊!,其实这个说法是错误的,其实p2指向的是该数组的首个元素,只不过是数组首个元素的地址跟数组首地址相同,执行p2++那么它会指向第二个元素,它指向的每个元素都是int类型的。
但是数组指针,比如所int (*p)[n],p或者p++指向的每个元素都是一个长度为n的一维数组。