float 转 unsigned char
#include <stdio.h>
#include <stdint.h>
int main() {
float value = 123.456f;
uint8_t bytes[4];
// 将float值转换为unsigned char数组
for (int i = 0; i < 4; i++) {
*(bytes + i) = *((uint8_t*) &value + i);
}
// 打印结果
for (int i = 0; i < 4; i++) {
printf("%02X ", bytes[i]);
}
return 0;
}
在上述代码中,我们首先定义了一个float
变量value
,然后定义了一个长度为4的uint8_t
数组bytes
,用于存储转换后的结果。
接下来,我们使用指针进行类型转换和数据截断。通过将value
的地址强制转换为uint8_t*
类型,我们可以访问每个字节的值。我们将每个字节的值存储到bytes
数组中。
最后,我们打印出转换后的结果。由于uint8_t
是无符号的,所以使用"%02X"格式化输出时,每个字节将以两个十六进制数的形式打印出来。
请注意,这种转换方式可能会导致精度损失和数据截断。在实际应用中,需要根据具体需求进行适当的处理。
printf(“%f\r\n”, accelerometer_dat.x);
float value = accelerometer_dat.x;
uint8_t bytes[4];
// 将float值转换为unsigned char数组
for (int i = 0; i < 4; i++) {
*(bytes + i) = *((uint8_t*) &value + i);
}
// 打印结果
HAL_UART_Transmit(&g_uart1_handle, (uint8_t*)bytes, (4), HAL_MAX_DELAY);
//
// for (int i = 0; i < 4; i++) {
// HAL_UART_Transmit(&g_uart1_handle, (uint8_t*)bytes, (4), HAL_MAX_DELAY);
// }