打印

节省代码空间

[复制链接]
1229|10
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
renyaq|  楼主 | 2013-4-25 19:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
long int转BCD, 越节省代码空间越好
沙发
ousj| | 2013-4-25 19:42 | 只看该作者
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;
                         }
                }
         }
}

使用特权

评论回复
板凳
dingy| | 2013-4-25 19:43 | 只看该作者
楼上的代码和速度肯定不行

使用特权

评论回复
地板
pengf| | 2013-4-25 19:44 | 只看该作者
单字节的乘除法是不怎么占空间,在汇编里面有乘除法的指令啊,是多字节的乘除法就占空间

使用特权

评论回复
5
juventus9554| | 2013-4-25 19:44 | 只看该作者
用循环减法,再把4个循环减法(-10000,-1000,-100,-10)合并到一个函数

使用特权

评论回复
6
llljh| | 2013-4-25 19:45 | 只看该作者
本帖最后由 llljh 于 2013-4-25 19:46 编辑

sprintf(buf, "%ld", l_value);

使用特权

评论回复
7
司徒老鹰| | 2013-4-25 19:47 | 只看该作者
sprintf。。。。。

使用特权

评论回复
8
zwll| | 2013-4-25 19:47 | 只看该作者
你这个方法只是效率高,并不省空间

使用特权

评论回复
9
chuxh| | 2013-4-25 19:48 | 只看该作者
10
chuxh| | 2013-4-25 19:48 | 只看该作者

去看看这个贴子,里面有省空间的,也有高效率的

使用特权

评论回复
11
leadman| | 2013-4-25 23:30 | 只看该作者
在存储空间里乘法肯定比较占用更多的空间

使用特权

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

本版积分规则

700

主题

10138

帖子

4

粉丝