Tengo el siguiente código para convertir un valor de BCD de 32 bits (suministrado en dos mitades de uint) a un valor binario uint.La manera más eficiente de convertir BCD a binario
Los valores suministrados pueden ser de hasta 0x9999, para formar un valor máximo de 0x99999999.
¿Existe alguna forma mejor (es decir, más rápida) de lograr esto?
/// <summary>
/// Convert two PLC words in BCD format (forming 8 digit number) into single binary integer.
/// e.g. If Lower = 0x5678 and Upper = 0x1234, then Return is 12345678 decimal, or 0xbc614e.
/// </summary>
/// <param name="lower">Least significant 16 bits.</param>
/// <param name="upper">Most significant 16 bits.</param>
/// <returns>32 bit unsigned integer.</returns>
/// <remarks>If the parameters supplied are invalid, returns zero.</remarks>
private static uint BCD2ToBin(uint lower, uint upper)
{
uint binVal = 0;
if ((lower | upper) != 0)
{
int shift = 0;
uint multiplier = 1;
uint bcdVal = (upper << 16) | lower;
for (int i = 0; i < 8; i++)
{
uint digit = (bcdVal >> shift) & 0xf;
if (digit > 9)
{
binVal = 0;
break;
}
else
{
binVal += digit * multiplier;
shift += 4;
multiplier *= 10;
}
}
}
return binVal;
}
Se ve bastante bien para mí. – Spence
¿Por qué se necesitan dos uints en lugar de ushorts, si cada uno solo representa 16 bits? –