C和指针 第八章 数组-指针的效率

本文探讨了C语言中使用指针与数组实现相同功能时的效率差异。通过对比try1到try5的代码实现,发现指针在数组操作中的效率优势,如try2和try3避免了下标的使用。寄存器变量的指针(try4, try5)在某些情况下可能提供额外的性能提升,并且在循环条件判断中避免运行时计算可以提高效率。
摘要由CSDN通过智能技术生成

C和指针 第八章 数组

指针的效率

将实现同一功能的不同C语言程序通过各自对应的汇编语言进行效率对比

#define SIZE 50
int i;
int x[SIZE];
int y[SIZE];
int *p1;
int *p2;

try1-3

try1

void try1(){
  for(i=0;i<SIZE;i++)
    x[i]=y[i];
}

在这里插入图片描述

try2

void try2(){
  for(p1=x,p2=y;p1-x<SIZE;)
    *p1++=*p2++;
}

在这里插入图片描述

try3

void try3(){
  for(i=0,p1=x,p2=y;i<SIZE;i++)
    *p1++=*p2++;
}

在这里插入图片描述

#define SIZE 50
int x[SIZE];
int y[SIZE];

try4-5

try4

void try4(){
  register int *p1, *p2;
  register int i;
  for(i=0,p1=x,p2=y;i<SIZE;i++)
    *p1++=*p2++;
}

在这里插入图片描述

try5

void try5(){
  register int *p1,*p2;
  for(p1=x,p2=y;p1<&x[SIZE])
    *p1++=*p2++;
}

在这里插入图片描述

对比

在这里插入图片描述
1.当你根据某个固定数目的增量在一个数组中移动时,使用指针变量将比使用下标产生效率更高的代码
2.声明为寄存器变量的指针通常比位于静态内存和堆栈中的指针效率更高(具体提高的幅度取决于你所用的机器)
3.若通过测试一些已经初始化并经过调整的内容来判断是否应该终止循环,那么你就不需要一个单独的计数器
4.运行时求值的表达式较&array[SIZE]或arrar+SIZE这样的常量表达式代价更高

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值