32位4字节单精度整型数转IEEE754浮点型数据
c
#include <stdio.h>
#include <stdint.h>
#include <string.h>
int main() {
// 假设这是一个32位浮点数的十六进制表示
uint32_t hex_array[1] = { 0x4048F5C2 };
// 使用 union 进行类型转换
union {
uint32_t as_uint;
float as_float;
} ieee_float;
ieee_float.as_uint = hex_array[0];
// 打印转换后的浮点数
float testData = ieee_float.as_float;
printf("Converted float value: %f\n", testData);
// 或者使用memcpy来避免类型别名问题
float copied_float;
memcpy(&copied_float, &hex_array, sizeof(float));
printf("Converted float value with memcpy: %f\n", copied_float);
return 0;
}
64位8字节双精度整型数转IEEE754浮点型数据
c
#include <stdio.h>
#include <stdint.h>
#include <string.h>
int main() {
// 假设这是一个64位浮点数的十六进制表示
uint64_t hex_array[1] = { 0x400921FB54442D18ULL };
// 使用 union 进行类型转换
union {
uint64_t as_ulong;
double as_double;
} ieee_double;
ieee_double.as_ulong = hex_array[0];
// 打印转换后的浮点数
printf("Converted double value: %lf\n", ieee_double.as_double);
// 或者使用memcpy来避免类型别名问题
double copied_double;
memcpy(&copied_double, &hex_array, sizeof(double));
printf("Converted double value with memcpy: %lf\n", copied_double);
return 0;
}