long int转BCD越节省代码空间越好

[复制链接]
46|11
| 2018-12-7 12:16 | 显示全部楼层

void Hex2Bcd(uint32 num)
{
        uchar i;
          if(num==0)
          {
                  for(i=9;i>0;i--)
                {
                         disp_buffer[i-1]=' ';
                                  }
                  disp_buffer[9]=0x30;
          }
          else
          {
                  for(i=10;i>0;i--)
                {
                        if(num==0)
                          {
                                  disp_buffer[i-1]=' ';
                          }
                          else
                          {
                                  disp_buffer[i-1] = ((num % 10)+0x30);
                                num /= 10;
                          }
                }
          }
}
| 2018-12-7 12:19 | 显示全部楼层
楼上的代码和速度肯定不行
| 2018-12-7 12:22 | 显示全部楼层
单字节的乘除法是不怎么占空间,在汇编里面有乘除法的指令啊,是多字节的乘除法就占空间
| 2018-12-7 12:25 | 显示全部楼层
用循环减法,再把4个循环减法(-10000,-1000,-100,-10)合并到一个函数
| 2018-12-7 12:30 | 显示全部楼层
sprintf(buf, "%ld", l_value);
| 2018-12-7 12:33 | 显示全部楼层


sprintf。。。。。
| 2018-12-7 12:37 | 显示全部楼层
你这个方法只是效率高,并不省空间
| 2018-12-7 12:45 | 显示全部楼层
去看看这个贴子,里面有省空间的,也有高效率的
| 2018-12-7 12:48 | 显示全部楼层

如果有BCD调整指令,可以用循环处理,速度快,代码效率高

51是有BCD指令的
 楼主 | 2018-12-7 12:54 | 显示全部楼层
嗯,我看下哈
扫描二维码,随时随地手机跟帖
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复

您需要登录后才可以回帖
登录 | 注册
高级模式
我要创建版块 申请成为版主

论坛热帖

快速回复 返回顶部 返回列表