char arr[3];
printf("arr:
%d
%d
%d
", arr, arr + 1, arr + 2);
char *parr[3];
printf("parr:
%d
%d
%d
", parr, parr + 1, parr + 2);
从结果可以看到,字符数组每个元素占1字节,字符指针数组每个占4字节。
再看一个例子:
char a = 'a', b = 'b', c = 'c', d = 'd';
char *arr[20] = {&a,&b,&c,&d};
char **parr = arr; //arr的类型也是char**
char *str;
printf("&a:%d,&b:%d,&c:%d,&d:%d
", &a, &b, &c, &d);
printf("&arr[0]:%d,&arr[1]:%d,&arr[2]:%d,&arr[3]:%d
", &arr[0], &arr[1], &arr[2], &arr[3]);
printf("arr:%d,parr:%d
", arr,parr);
printf("*parr:%d,**parr:%c
", *parr, **parr);
str = *parr; //arr[0],char*类型
printf("----- str=*parr -----
");
printf("str:%d,*str:%c
", str, *str);
str++;
printf("----- str++ -----
");
printf("str:%d,*str:%c
", str, *str);
str = *(parr + 1);
printf("----- str=*(parr+1) -----
");
printf("str:%d,*str:%c
", str, *str);
str = *(parr + 2); //*(arr+2*4)
printf("----- str=*(parr+2) -----
");
printf("str:%d,*str:%c
", str, *str);
指针的加减运算,就是将指针当前值与sizeof(指针指向的类型)相加减。
比如上例中str=*parr,这时str当前值为arr[0],指向的类型是一个字符(所以大小为1字节),str++就代表arr[0]+1*1,但是由于指针数组的每一项占4字节,所以之后的*str输出为?。
再比如上例中str=*(parr+1),指针parr当前值为arr,指向的类型是一个字符指针char*类型(所以大小为4字节),parr+1就代表arr+1*4,向高地址方向移动4个字节,即&arr[0]+4==&arr[1],str就变成了arr[1],所以之后输出的*str为b。
另外
指针和指针进行加减:两个指针不能进行加法运算,这是非法操作,因为进行加法后,得到的结果指向一个不知所向的地方,而且毫无意义。两个指针可以进行减法操作,但必须类型相同,一般用在数组方面,不多说了。