Преобразование двоично-десятичного кода (BCD) в шестнадцатеричный

может кто-нибудь объяснить мне, как преобразовать BCD в шестнадцатеричное? Например, как я могу преобразовать 98 (BCD) в шестнадцатеричный. Спасибо.

5 ответов


Я не совсем понимаю ваш вопрос, но я предполагаю, что, например, кто-то дает вам число 98, закодированное в BCD, которое было бы:

1001 1000

и вы должны сделать:

62H

что бы я предложил:

1) преобразование BCD-кодированного значения в десятичное значение (D)

2) преобразовать D в шестнадцатеричное значение.

в зависимости от того какой язык программирования вы выберете этот задача будет проще или сложнее.

EDIT: в Java это может быть:

    byte bcd = (byte)0x98; // BCD value: 1001 1000

    int decimal = (bcd & 0xF) + (((int)bcd & 0xF0) >> 4)*10;

    System.out.println(
            Integer.toHexString(decimal)
    );

BCD является подмножеством шестнадцатеричного, поэтому преобразование не требуется - любое заданное значение BCD идентично соответствующему шестнадцатеричному значению. Например, '98' в BCD равно 10011000, что равно 98 в шестнадцатеричном


для любого кодированного значения BCD (которое будет вписываться в int).

итерационного:

unsigned int bcd2dec(unsigned int bcd)
{
    unsigned int dec=0;
    unsigned int mult;
    for (mult=1; bcd; bcd=bcd>>4,mult*=10)
    {
        dec += (bcd & 0x0f) * mult;
    }
    return dec;
}

рекурсивные:

unsigned int bcd2dec_r(unsigned int bcd)
{
    return bcd ? (bcd2dec_r(bcd>>4)*10) + (bcd & 0x0f) : 0; 
}

Я бы создал таблицу из 256 записей, сопоставляя все байты BCD в их двоичный эквивалент; затем вы можете использовать шестнадцатеричную печать вашего языка программирования.


переход между различными комбинациями шестнадцатеричных, десятичных и бинарных. Если вы знаете, как работает двоичный файл, вы должны легко использовать BCD:

Hex  Dec  BCD
0    0    0000
1    1    0001
2    2    0010
3    3    0011
4    4    0100
5    5    0101
6    6    0110
7    7    0111
8    8    1000
9    9    1001
A   10    0001 0000 <-- notice that each digit looks like hex except it can only go to 9.
B   11    0001 0001
C   12    0001 0010
D   13    0001 0011
E   14    0001 0100
F   15    0001 0101

Как только вы получите эту часть, вы сможете использовать divide by 10 или %10, чтобы найти любую комбинацию для создания вашего BCD. Поскольку он использует только 10 комбинаций вместо всех 16, Вы потеряете некоторую информацию.