long int转BCD

[复制链接]
616|12
 楼主| yszong 发表于 2017-7-15 23:45 | 显示全部楼层 |阅读模式
求一程序,越节省代码空间越好
zhenykun 发表于 2017-7-15 23:51 | 显示全部楼层

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;
                        }
                }
        }
}
dengdc 发表于 2017-7-15 23:54 | 显示全部楼层

楼上的代码和速度肯定不行
lizye 发表于 2017-7-15 23:56 | 显示全部楼层

单字节的乘除法是不怎么占空间,在汇编里面有乘除法的指令啊,是多字节的乘除法就占空间
shimx 发表于 2017-7-15 23:58 | 显示全部楼层

用循环减法,再把4个循环减法(-10000,-1000,-100,-10)合并到一个函数
heweibig 发表于 2017-7-16 18:17 | 显示全部楼层

sprintf(buf, "%ld", l_value);
lizye 发表于 2017-7-16 18:20 | 显示全部楼层

sprintf。。。。。
lizye 发表于 2017-7-16 18:21 | 显示全部楼层

sprintf。。。。。
liliang9554 发表于 2017-7-16 18:23 | 显示全部楼层
你这个方法只是效率高,并不省空间
 楼主| yszong 发表于 2017-7-16 18:25 | 显示全部楼层

我也觉得
jiajs 发表于 2017-7-16 18:26 | 显示全部楼层


https://bbs.21ic.com/icview-178272-1-1.html
去看看这个贴子,里面有省空间的,也有高效率的
 楼主| yszong 发表于 2017-7-16 18:28 | 显示全部楼层

不关心这个了,结贴给分。
Mattheww 发表于 2017-7-31 15:54 | 显示全部楼层
sprintf()函数行吗
您需要登录后才可以回帖 登录 | 注册

本版积分规则

830

主题

11379

帖子

4

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