后缀++
假如需要将一个值存入一个数组元素中,然后再前进到下一个元素,那么利用数组下标可以这样写:
data[i++]=j;
如果pData指向数组元素,那么相应的语句为:
*pData++=j;
因为后缀++的优先级高于*,所以编译器将上述语句看成是:
*(dData)=;
pData++的值是pDdata,因为使用后缀++,所以pData只有在表达式计算出来后才可以自增,那么*(pData++)的值为*pData,即pData当前指向的对象。因此可以将
for(pData = &data[0]; pData < &data[N]; pData++)
sum += *pData;
改写为
pData = &data[0];
while(pData < &data[N])
sum += *pData++;
前缀++
*++pData与*(++pData)一样,先自增pData
#include <stdio.h>
#include <stdlib.h>
int main()
{
int data[10]={0,2,3,4,5,6,7,8,9,0};
int *pData=data;
printf("*++pData=%d\n",*++pData);
return 0;
}
和
#include <stdio.h>
#include <stdlib.h>
int main()
{
int data[10]={0,2,3,4,5,6,7,8,9,0};
int *pData=data;
printf("*(++pData)=%d\n",*(++pData));
return 0;
}
结果是一样的:
解析:先自增pData,pData=data=&data[0],即是第0个元素的地址,自增后为第一个元素的地址,然后解引用,即得到值为2;
- ++*pData和++(*pData)
#include <stdio.h>
#include <stdlib.h>
int main()
{
int data[10]={0,2,3,4,5,6,7,8,9,0};
int *pData=data;
printf("++*pData=%d\n",++*pData);
return 0;
}
和
#include <stdio.h>
#include <stdlib.h>
int main()
{
int data[10]={0,2,3,4,5,6,7,8,9,0};
int *pData=data;
printf("++(*pData)=%d\n",++(*pData));
return 0;
}
结果:
解析:++*pData和++(*pData)是先自增*pData,因为pData=data=&data[0];所以先取&data[0]得值(0),然后自增的1;