免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1562 | 回复: 4
打印 上一主题 下一主题

[有点汇编]为什么? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-05-03 23:15 |只看该作者 |倒序浏览
.L0:
addl   (%eax,%edx,4), %ecx
incl     %edx
cmpl   %edi,%edx
jl        .L0

.L1
addl   (%eax),%ecx
addl  $4,%eax
cmpl   %edx,%eax
jb      .L0



请问第一个迭代要几个指令周期?第二个呢?为什么?

论坛徽章:
0
2 [报告]
发表于 2008-05-04 00:22 |只看该作者

回复 #1 lishizelibin 的帖子

LZ 这段是典型的数组下标法与指针法的比较吧

  1. int sum(int a[], int l)
  2. {
  3.       int i = 0;
  4.       int s = 0;
  5.       for (; i < l; i++)
  6.           s += a[i];

  7.       return s;
  8. }
  9. -----------------------------------
  10. int __sum(int *a, int l)
  11. {
  12.         int *p = &a[l-1];
  13.         int s = 0;

  14.         while (a <= p)
  15.               s += *a++;

  16.         return s;
  17. }
复制代码


------------------------------------
这段代码的指令周期可以说是一样的:

addl   (%eax,%edx,4), %ecx    与   addl   (%eax),%ecx
指令周期是一样的,源操作数都是内存操作数.
addl  $4,%eax    与   incl     %edx  也是一样的

[ 本帖最后由 mik 于 2008-5-4 00:23 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2008-05-04 09:29 |只看该作者
原帖由 mik 于 2008-5-4 00:22 发表
LZ 这段是典型的数组下标法与指针法的比较吧

int sum(int a[], int l)
{
      int i = 0;
      int s = 0;
      for (; i < l; i++)
          s += a;

      return s;
}
------------------- ...


顶...

论坛徽章:
0
4 [报告]
发表于 2008-05-04 11:55 |只看该作者
原帖由 mik 于 2008-5-4 00:22 发表
LZ 这段是典型的数组下标法与指针法的比较吧

int sum(int a[], int l)
{
      int i = 0;
      int s = 0;
      for (; i < l; i++)
          s += a;

      return s;
}
------------------- ...

但是第一个是两个周期,第二个是三个周期,我就弄不明白了。难道incl受到什么处理?对了这是否和预测流水线有关?

论坛徽章:
0
5 [报告]
发表于 2008-05-04 14:48 |只看该作者
还有人有看法么?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP