学数组与指针一点感悟

#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

这段程序是分析数组与指针那个运行速度快,由此可见指针的运行速度比数组的快一些,当运算的数据越大的时候,指针的优势越大。

猜你喜欢

转载自blog.csdn.net/wsqfly06/article/details/78719299