数据可能以 24 位格式编码。需要在处理这些数据时进行正确的解析和转换。
#include <stdint.h>
#include <stdio.h>
// 将 24 位有符号整数(存储为 3 字节的数组)转换为 32 位整数
int32_t int24to32(uint8_t bytes[3]) {
// 将 24 位整数转换为 32 位整数
int32_t result = (bytes[0] << 16) | (bytes[1] << 8) | bytes[2];
// 如果最高位是 1,则需要进行符号扩展
if (result & 0x00800000) { // 0x00800000 是 24 位整数的符号位位置
result |= 0xFF000000; // 扩展符号位到 32 位
}
return result;
}
int main() {
// 24 位有符号整数的字节表示
uint8_t test_data[8][3] = {
{0x7F, 0xFF, 0xFF}, // 0x7FFFFF -> 8388607
{0x40, 0x00, 0x00}, // 0x400000 -> 4194304
{0x00, 0x00, 0x01}, // 0x000001 -> 1
{0x00, 0x00, 0x00}, // 0x000000 -> 0
{0xFF, 0xFF, 0xFF}, // 0xFFFFFF -> -1
{0xC0, 0x00, 0x00}, // 0xC00000 -> -4194304
{0x80, 0x00, 0x00} // 0x800000 -> -8388608
};
// 期望的结果
int32_t expected_results[8] = {
8388607, // 0x7FFFFF
4194304, // 0x400000
1, // 0x000001
0, // 0x000000
-1, // 0xFFFFFF
-4194304, // 0xC00000
-8388608 // 0x800000
};
int i;
// 检验每一个数据
for (i = 0; i < 7; i++) {
int32_t result = int24to32(test_data[i]);
printf("Testing 24-bit value 0x%02X%02X%02X:\n", test_data[i][0], test_data[i][1], test_data[i][2]);
printf(" Result: %d\n", result);
printf(" Expected: %d\n", expected_results[i]);
printf(" Test %s\n\n", result == expected_results[i] ? "ok" : "error");
}
return 0;
}
常见场景:
嵌入式系统和硬件接口
- 24 位模拟数字转换器 (ADC)
- 传感器数据: 一些传感器或外设可能以 24 位有符号整数格式传输数据。
- 通信协议: 在某些通信协议中,