#include<stdio.h>
intmain(int argc, char **argv)
{
int a[3]={0};
printf("%0x\n",a+1);
printf("%0x\n",&a+1);
printf("%0x\n",a);
return 0;
}
结果为:bfc9841c
bfc98424
bfc98418
这道程序分析的是a与&a不同,可程序可知a与a+1相差4字节,与&a+1相差12字节,a是数组的首元素地址与整个数组地址重合,与&a的值相同,但所代表的意义不同。a是扫过第一个元素空间,而&a扫过整个数组空间,其相差8个字节,所以&a+1就跳出了这个数组。
intmain1()
{
clock_tstart;
clock_tend;
inta[10000];
intb[10000];
int*pEnd=&a[10000];
int*pa=NULL;
int*pb=NULL;
inti=0;
intk=0;
start=clock();
for(k=0;k<10000;k++)
{
for(i=0;i<10000;i++)
{
b[i]=a[i];
}
}
end= clock();
printf("IndexTiming:%d\n",end-start);
start=clock();
for(k=0;k<10000;k++)
{
for(pa=a,pb=b;pa<pEnd;)
{
*pb++=*pa++;
}
}
end=clock();
printf("PointerTiming:%d\n",end-start);
return 0;
}
当inta[10000];
int b[10000];时
IndexTiming:400000
PointerTiming:370000
当int a[50000];
int b[50000];时
IndexTiming:9630000
PointerTiming:9040000
这段程序是分析数组与指针那个运行速度快,由此可见指针的运行速度比数组的快一些,当运算的数据越大的时候,指针的优势越大。