专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
请问下,4节字节的长整型数转换为BCD码,怎么样做最快呢。。
2020-01-16 18:31
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
6787
18
18
假设一个,long int k = 1234567890;转换为,unsigned char k1[10];
这个应该怎么算比较好呢。比较常见的是,
for(i =0 ;i<10;i++)
{
k1
= k%10;
k/=10;
}
应该有更简单的吧。。
谢谢!
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
17条回答
hetao7241
1楼-- · 2020-01-16 19:57
搜一下,坛里好像有的。
加载中...
lollipop
2楼-- · 2020-01-17 00:32
精彩回答 2 元偷偷看……
加载中...
newc
3楼-- · 2020-01-17 03:21
这个查表?怎么查,看另一个贴子用的是,先判断再用减法来做的。
加载中...
eduhf_123
4楼-- · 2020-01-17 03:45
帖一个我做的库:
NAME LONG2BCD
?PR?_long2bcd?LONG2BCD SEGMENT CODE INBLOCK
PUBLIC _long2bcd
; void long2bcd(unsigned long l, unsigned char * p)
RSEG ?PR?_long2bcd?LONG2BCD
_long2bcd:
MOV R3, #0x05
CLR A
?C0001: MOV @R1, A
INC R1
DJNZ R3, ?C0001
MOV A, #0x08
MOV R2, A
?C0002: XCH A, R4
RLC A
XCH A, R4
MOV R3, #0x02
?C0003: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C ;PSW.5,F0
ADD A, #0x33
JB 0xE3, ?C0004 ;ACC.3
ADD A, #(-3)
?C0004: JB 0xE7, ?C0005 ;ACC.7
ADD A, #(-48)
?C0005: MOV C, 0xD5 ;PSW.5,F0
XCH A, @R1
DJNZ R3, ?C0003
INC R1
INC R1
DJNZ R2, ?C0002
MOV R2, A
?C0006: XCH A, R5
RLC A
XCH A, R5
MOV R3, #0x03
?C0007: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
ADD A, #0x33
JB 0xE3, ?C0008
ADD A, #(-3)
?C0008: JB 0xE7, ?C0009
ADD A, #(-48)
?C0009: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C0007
INC R1
INC R1
INC R1
DJNZ R2, ?C0006
MOV R2, A
?C000A: XCH A, R6
RLC A
XCH A, R6
MOV R3, #0x04
?C000B: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
ADD A, #0x33
JB 0xE3, ?C000C
ADD A, #(-3)
?C000C: JB 0xE7, ?C000D
ADD A, #(-48)
?C000D: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C000B
INC R1
INC R1
INC R1
INC R1
DJNZ R2, ?C000A
MOV R2, A
?C000E: XCH A, R7
RLC A
XCH A, R7
MOV R3, #0x05
?C000F: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
CJNE R2, #1, ?C0010
SJMP ?C0012
?C0010: ADD A, #0x33
JB 0xE3, ?C0011
ADD A, #(-3)
?C0011: JB 0xE7, ?C0012
ADD A, #(-48)
?C0012: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C000F
INC R1
INC R1
INC R1
INC R1
INC R1
DJNZ R2, ?C000E
RET
END
所用算法的流程图
(原文件名:hex2bcd.JPG)
C语言的调用接口已在程序中以注释的方式给出,需要注意的是,程序需要传递一个通用指针进去,但函数内部的代码实际上只能处理该指针为“unsigned char data *”的形式,也就是说,存储BCD码结果的数组只能在DATA区。结果为压缩BCD码,存于传进来的指针所指的5个元素的数组。
附上库文件工程包、测试工程包:
生成.LIB库文件的工程包
ourdev_549026.rar(文件大小:5K)
(原文件名:long2bcd.rar)
功能测试及、与除法及取模运算方式对比的工程包
ourdev_549027.rar(文件大小:7K)
(原文件名:temp.rar)
在标准51架构上,该函数使用2174周期、而作为对比的除法/取模方式要用4700周期。
本想使用div/ldiv库来改善除法/取模方式的效率,结果查阅Keil的帮助才发现,Keil C不支持这两个ANSI-C的库,看样子有必要自己写一个。
加载中...
oldmen
5楼-- · 2020-01-17 07:43
hao
加载中...
yusufu
6楼-- · 2020-01-17 12:12
学习了
加载中...
1
2
3
下一页
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
东软载波ESF0654 PDS开发板串口USART0代码分享
1 个回答
普通32位单片机使用linux的应用代码
5 个回答
东软载波ESF0654 PDS开发板AT24C04的调试
9 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
NAME LONG2BCD
?PR?_long2bcd?LONG2BCD SEGMENT CODE INBLOCK
PUBLIC _long2bcd
; void long2bcd(unsigned long l, unsigned char * p)
RSEG ?PR?_long2bcd?LONG2BCD
_long2bcd:
MOV R3, #0x05
CLR A
?C0001: MOV @R1, A
INC R1
DJNZ R3, ?C0001
MOV A, #0x08
MOV R2, A
?C0002: XCH A, R4
RLC A
XCH A, R4
MOV R3, #0x02
?C0003: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C ;PSW.5,F0
ADD A, #0x33
JB 0xE3, ?C0004 ;ACC.3
ADD A, #(-3)
?C0004: JB 0xE7, ?C0005 ;ACC.7
ADD A, #(-48)
?C0005: MOV C, 0xD5 ;PSW.5,F0
XCH A, @R1
DJNZ R3, ?C0003
INC R1
INC R1
DJNZ R2, ?C0002
MOV R2, A
?C0006: XCH A, R5
RLC A
XCH A, R5
MOV R3, #0x03
?C0007: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
ADD A, #0x33
JB 0xE3, ?C0008
ADD A, #(-3)
?C0008: JB 0xE7, ?C0009
ADD A, #(-48)
?C0009: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C0007
INC R1
INC R1
INC R1
DJNZ R2, ?C0006
MOV R2, A
?C000A: XCH A, R6
RLC A
XCH A, R6
MOV R3, #0x04
?C000B: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
ADD A, #0x33
JB 0xE3, ?C000C
ADD A, #(-3)
?C000C: JB 0xE7, ?C000D
ADD A, #(-48)
?C000D: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C000B
INC R1
INC R1
INC R1
INC R1
DJNZ R2, ?C000A
MOV R2, A
?C000E: XCH A, R7
RLC A
XCH A, R7
MOV R3, #0x05
?C000F: DEC R1
XCH A, @R1
RLC A
MOV 0xD5, C
CJNE R2, #1, ?C0010
SJMP ?C0012
?C0010: ADD A, #0x33
JB 0xE3, ?C0011
ADD A, #(-3)
?C0011: JB 0xE7, ?C0012
ADD A, #(-48)
?C0012: MOV C, 0xD5
XCH A, @R1
DJNZ R3, ?C000F
INC R1
INC R1
INC R1
INC R1
INC R1
DJNZ R2, ?C000E
RET
END
所用算法的流程图 (原文件名:hex2bcd.JPG)
C语言的调用接口已在程序中以注释的方式给出,需要注意的是,程序需要传递一个通用指针进去,但函数内部的代码实际上只能处理该指针为“unsigned char data *”的形式,也就是说,存储BCD码结果的数组只能在DATA区。结果为压缩BCD码,存于传进来的指针所指的5个元素的数组。
附上库文件工程包、测试工程包:
生成.LIB库文件的工程包ourdev_549026.rar(文件大小:5K) (原文件名:long2bcd.rar)
功能测试及、与除法及取模运算方式对比的工程包ourdev_549027.rar(文件大小:7K) (原文件名:temp.rar)
在标准51架构上,该函数使用2174周期、而作为对比的除法/取模方式要用4700周期。
本想使用div/ldiv库来改善除法/取模方式的效率,结果查阅Keil的帮助才发现,Keil C不支持这两个ANSI-C的库,看样子有必要自己写一个。
一周热门 更多>