我有一个将uint16_t
转换为BCD的功能。
uint16_t uint162BCD(uint16_t value)
{
uint16_t b_val = 0;
unsigned int shift = 0;
while (shift / 8 < sizeof(bcd))
{
b_val = static_cast<uint16_t>(b_val + ((value % 10) << shift));
value = value / 10;
shift = shift + 4;
}
return b_val;
}
我用以下值进行了小型单元测试
ASSERT_EQ(uint162BCD(0), (uint16_t) 0x0);
ASSERT_EQ(uint162BCD((uint16_t) 1), (uint16_t) 0x1);
ASSERT_EQ(uint162BCD((uint16_t) 12), (uint16_t) 0x12);
ASSERT_EQ(uint162BCD((uint16_t) 123), (uint16_t) 0x123);
ASSERT_EQ(uint162BCD((uint16_t) 56), (uint16_t) 0x56);
这些似乎可以按预期进行转换。但是,如果我这样做。
ASSERT_EQ(uint162BCD((uint16_t) 0056), (uint16_t) 0x56);
它不起作用。我期望与0x56相同的值。我在做什么错了?
答案 0 :(得分:6)
ASSERT_EQ(uint162BCD((uint16_t) 0056), (uint16_t) 0x56);
以C或C ++开头的以“ 0”开头的文字整数被解释为八进制数。人类用十根手指将“ 0056”称为“ 46”。