一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

手机号码,快捷登录

手机号码,快捷登录

搜索
查看: 6701|回复: 6

BCD码转十进制

[复制链接]
发表于 2012-4-15 15:04 | 显示全部楼层 |阅读模式
  private static int IntToBCD(int i) //十进制转BCD: _8 K9 h+ k1 V0 I; Z- K- w
        {
9 T& J) M( b, {( S  B# B. B            return (((i / 10) << 4) + ((i % 10) & 0x0f));
4 F+ }- }- Y7 X        }) p8 V1 r, o' K! s7 N
        private static int BCDToInt(byte bcd) //BCD转十进制
  ?$ q8 [6 r3 D% ]/ |9 x        {
3 e! u& D, a. y. Y            return (0xff & (bcd >> 4)) * 10 + (0xf & bcd);3 O, a* P7 [: [; H
        }: ?, ~% t& d( [$ [; \: k) G
发表于 2012-4-15 15:25 | 显示全部楼层
private static int BCDToInt(byte bcd) //BCD转十进制2 P! Q9 ~3 D. b' H& l* E, y
        {% d" K, M6 H+ r/ M0 O+ Q
            return (0xff & (bcd >> 4)) * 10 + (0xf & bcd);* F5 R, d- ^( s0 H5 @. H' d" f
        }: }4 E5 j/ @' x! L- \+ ]9 p0 U3 ~; m
0 t- Z2 ?. r7 J
至少这里错了。
回复

使用道具 举报

发表于 2012-4-15 15:26 | 显示全部楼层
private static int IntToBCD(int i) //十进制转BCD5 N  ?# }' M2 E# O' x# D
        {
$ ^8 i4 C/ A, U3 B- n            return (((i / 10) << 4) + ((i % 10) & 0x0f));
4 s  n, @8 w3 k' b7 m        }8 K! P) v+ `3 H2 v8 F
3 ]- T* C& f& `) [/ I' Q
考虑一下红色部分是否必要。
回复

使用道具 举报

发表于 2012-4-15 15:28 | 显示全部楼层
还有,
2 G' O5 G$ z' u" ~9 rprivate static int IntToBCD(int i)) ^# i2 o- `3 }$ l, G% J& P
红色部分改为byte比较安全。
回复

使用道具 举报

 楼主| 发表于 2012-4-15 15:32 | 显示全部楼层
今天有人在问我BCD码如何转换成10进制码的问题
* y2 S" k7 ?2 C, q其实很简单% p7 \6 l3 m/ G* x" Y$ Y+ O
BCD 的表示法是 用4个二进制位来表示 一个十进制位,也就是一个字节能够表示2个十进制数位,这是一种压缩的十进制表示方式,应用很广,最常见的就是CMOS里的时间存放格+ g" H3 i* t; n: k4 z  b6 t

( e9 c. q2 H# V5 @4 u9 {& \! G式就是BCD码格式,更具体的表示方法大家可以去百度一下就知道了不过其实知道我上面说的就差不多了。' R6 ^" E5 a8 E, y8 z9 [
明白了BCD是怎么表示后转换也就容易了,低4位和高4位分别转换然后合并起来就是了!
( r( p  H) @' a$ q" j) ]  G. q如15用BCD码表示为 0001 0101
1 o3 h( w3 T5 [) w5 |/ }低四位的值就是实现十进制数的低四,高4位就是高四位的值,这样我们有很高效的转换方法
" r5 \; _' a4 e  \! m6 S6 L7 i低四位+高四位×10 (上面是2位十进制数的)& s. ^! o9 x9 u/ R
% t8 R0 y! m) W1 s* ?# x
用C语言表达一下可能更能明白我上面说的意思
, u9 t- Q, ]  o#include <stdio.h># p2 B& V) w1 W. [0 \1 l
4 H& ^/ z+ y& z: e" ^; O
int main(void). b  t) i+ u6 d
{
8 ]* ~2 b: R. Z/ y; r* i    /** 15用BCD码表示为 0001 0101 **/
& f6 s+ R- H3 ~) s  v    int bcd = 0x15;
. Q' I( Q: `! a9 Z# |5 _, }    int dec;! }  B8 ?) C# y
5 M' {+ I4 s/ u& t0 J2 Z* M& D
    dec = (bcd & 15) + ((bcd>>4) * 10);- \6 S0 O8 c% P9 k
8 u( ]- _9 P9 x/ a& ~
    printf("%d\n",dec);
8 A7 l7 V0 H5 \* [; V    return 0;3 W4 Q; g" s1 S9 q/ W
}- F/ ^  H8 y3 N
6 o! E' {4 E3 K5 }  A
所以实际转换可以定义成一个宏
5 y% m% ?" @$ g) f#define BCDTODEC(bcd)
# S0 H: W+ l) @
# ~8 l( N: h9 [# a; y: a# n1 e& z" V
( r! u5 a: E& `+ A+ x9 j' @7 N& c8 ?" |  M" i$ g! X* @" c9 p
#include <stdio.h>
7 N1 l" k  K* b' @- Q#define BCDTODEC(bcd) ((bcd) = ((bcd) & 15) + ((bcd)>>4) * 10)
2 B, j' t8 _0 }- ]int main(void)
' A( t# I& R) I" t# n{
9 d# O. }5 x1 K  v8 B5 t    /** 15用BCD码表示为 0001 0101 **/# _* _* I' n4 d! _
    int bcd = 0x15;7 j0 b6 Q' Y2 c" n$ s0 L
    BCDTODEC(bcd);: C' T( N% j$ {- R0 z
    printf("%d\n",bcd);
( h9 U) b/ T* p, T- v    return 0;7 H2 g4 y6 o& y; W) Q
}
回复

使用道具 举报

 楼主| 发表于 2012-4-15 16:12 | 显示全部楼层
private static int BCDToInt(byte bcd) //BCD转十进制7 w  X5 {+ W0 u9 v
        {
) L4 V9 l* J. t# J  I' O            return (0xff & (bcd >> 4 ...
) G: i/ x1 R3 c+ y& }7 Fchjj0 发表于 2012-4-15 15:25 https://www.yleee.com.cn/images/common/back.gif

' p3 U0 x1 B* G: d% l7 s* ~6 J4 S4 }9 [* Y1 `
1 Q1 w- ]* k5 z. D: k, D( h
   说得对0xff其实并没有用的,谢谢提醒。
回复

使用道具 举报

 楼主| 发表于 2012-4-15 16:18 | 显示全部楼层
其实BCD 码的转换其实是加减权的方法来实现的,够10的话就左移这样就变成BCD码,右移就变成进制。
回复

使用道具 举报

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2026-4-17 17:55 , Processed in 0.041403 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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