以指针的形式访问数组:
下标表达式:后缀表达式[表达式]
在C语言中,根据定义,表达式e1[e2]准确地对应于表达式*((e1)+(e2)).
因此,要求表达式e1[e2]的其中一个操作数是指针,另一个操作数是整数,且这两个操作数的顺序可以颠倒。
故:a[4]等同于4[a]等同于*(a+4)。
编译器把所有的e1[e2]表达式转换成*((e1)+(e2))。
下标表达式:后缀表达式[表达式]
在C语言中,根据定义,表达式e1[e2]准确地对应于表达式*((e1)+(e2)).
因此,要求表达式e1[e2]的其中一个操作数是指针,另一个操作数是整数,且这两个操作数的顺序可以颠倒。
故:a[4]等同于4[a]等同于*(a+4)。
编译器把所有的e1[e2]表达式转换成*((e1)+(e2))。
所以,以下标的形式访问在本质上与以指针的形式访问没有区别,只是写法上不同罢了!
#include<stdio.h>
#include<string.h>
int main(void)
{
int n;
char y[10] = "ntse";
char *x = y;
n = strlen(x);
//*x = y[3];
//*x = x[3];
//*x = *(y+3);
//*x = *(x+3);
*x = 3[y];
//*x = 3[x];
//*x = x[n];
x++;
printf("n=%d\n",n);
printf("x=%s\n",x);
printf("y=%s\n",y);
return 0;
}
对*x=x[n]而言:
因为n=4,*x=x[n]的功能是将x指向的第一个字符修改为‘\0’,这样y字符串就结束了,所以第三个输出结果为空,x++操作以后,x指向第二个字符,第二个输出结果为tse。
对剩下的几个而言:
效果都一样,输出结果都是:
n=4
x=tse
y=etse