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

[复制链接]
462|12
 楼主| yszong 发表于 2019-7-13 15:19 | 显示全部楼层 |阅读模式
long int转BCD越节省代码空间越好
wuhany 发表于 2019-7-13 15:22 | 显示全部楼层
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;
                         }
                }
         }
}
午夜粪车 发表于 2019-7-13 15:24 | 显示全部楼层


楼上的代码和速度肯定不行
zhaoxqi 发表于 2019-7-13 15:29 | 显示全部楼层
单字节的乘除法是不怎么占空间,在汇编里面有乘除法的指令啊,是多字节的乘除法就占空间
jlyuan 发表于 2019-7-13 15:33 | 显示全部楼层

用循环减法,再把4个循环减法(-10000,-1000,-100,-10)合并到一个函数
huangchui 发表于 2019-7-13 15:36 | 显示全部楼层
sprintf(buf, "%ld", l_value);
 楼主| yszong 发表于 2019-7-13 15:40 | 显示全部楼层

sprintf。。。。。
wuhany 发表于 2019-7-13 15:45 | 显示全部楼层

你这个方法只是效率高,并不省空间
jiajs 发表于 2019-7-13 15:49 | 显示全部楼层


https://bbs.21ic.com/icview-178272-1-1.html
去看看这个贴子,里面有省空间的
jiajs 发表于 2019-7-13 15:52 | 显示全部楼层
也有高效率的
jiahy 发表于 2019-7-13 15:56 | 显示全部楼层

这个主要在算法当中的,,优化算法的作用就是这个的。
lizye 发表于 2019-7-13 15:59 | 显示全部楼层

这个取决于算法的吧。。
 楼主| yszong 发表于 2019-7-13 16:05 | 显示全部楼层
好的,我明天去单位试一下,多谢各位大侠了哈,结贴了先
您需要登录后才可以回帖 登录 | 注册

本版积分规则

830

主题

11379

帖子

4

粉丝
快速回复 在线客服 返回列表 返回顶部