哪种方法速度更快

[复制链接]
1283|6
手机看帖
扫描二维码
随时随地手机跟帖
guoyt|  楼主 | 2011-5-12 16:29 | 显示全部楼层 |阅读模式
需要查表,表是无序的
表头是两个字节
第一种

for(i=0;i<MAX;i++)
{
    if(*((INT16U*)ch) == *((INT16U*)&(data[i].index)))
                     return &data[i];
}

第二种
for(i=0;i<MAX;i++)
{
     if((*ch == data[i].index[0])  && (*(ch+1) == data[i].index[1]))
                      return &data[i];
}

个人感觉8位机的第2种快些,32位机或16位机的第一种快些;
谁能分析下
hanwe| | 2011-5-12 17:41 | 显示全部楼层
第二种会快一些

使用特权

评论回复
guoyt|  楼主 | 2011-5-12 18:14 | 显示全部楼层
为什么

使用特权

评论回复
hanwe| | 2011-5-12 18:36 | 显示全部楼层
写成下面这个形式就知道了
for(i=0;i<MAX;i++)
{
if(ch[0] == data.index[0])
  if(ch[1] == data.index[1])
    return &data;
}

使用特权

评论回复
dolido| | 2011-5-24 16:14 | 显示全部楼层
貌似第二种吧

使用特权

评论回复
wowewo| | 2011-5-24 16:17 | 显示全部楼层
新手围观

使用特权

评论回复
hihu| | 2011-5-26 13:34 | 显示全部楼层
帮顶

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1018

主题

9067

帖子

3

粉丝