指针的运算
例1:
char a[20];
int *p=(int *)a;//强转并不会改变a的类型
p++;
指针变量p被初始化为指向整型变量a,即p里面是数值a的首地址,然后p+1,即指针+1,但编译器这样处理:p是一个整型类型的指针,int占4个字节,由于地址是以字节为单位,故p所指向的地址+上一个单位,即p所指向的地址由原来的变量a的地址向高地址方向增加了4个字节,此时指向了数组a 中从第4 号单元开始的四个字节。
例2
char a[20]="abcdefg";
int *p=(int *)a;
p+=3;
因为p的类型是int *的类型,所以p+=3
+上3个单位的int的字节,即此时的地址向高地址方向增加了12个字节。
例3
char a[10]={“abcdefg”};
char *p=a;
char **p=&a;
printf("**p=%c\n",**p);
p++;
printf("**p=%c\n",**p);
/*p的类型是char **,指向的类型是一个char*类型
,该指向的地址是(&p),当执行p++时,会使指针加一个(sizeof(char*))即&p+4;但是*(&p+4)不知道指向哪里,所以第二个输出是个错误的输出!
*/
在32位系统中,指针的类型是4个字节。64位则占8个字节!
例4:
“++”与“*”运算优先级相同,从右向左!
*p++;//p先进行++,后与*进行运算
(*p)++;//p先与*进行运算,后++