C语言:把两个16位的数据合成32位浮点型数据

把两个 16 位的数据(uint16_t)合成一个 32 位的 float 数据,可以按照以下步骤来实现:

  1. 从两个 16 位数据恢复出 4 个字节
  2. 将 4 个字节合并成一个 32 位的 float 数据

已经有两个 16 位数据:uint16_t high16uint16_t low16,这两个数据存储了一个 32 位 float 的低 16 位和高 16 位。你可以按以下方法将它们合成一个 float 数据:

代码实现

#include <stdio.h>
#include <stdint.h>

float combine16ToFloat(uint16_t high16, uint16_t low16) {
    uint32_t combined = ((uint32_t)high16 << 16) | low16;  // 合并两个 16 位数据
    float result;
    // 将 32 位的整数按浮动转换为 float
    memcpy(&result, &combined, sizeof(result));  // 使用 memcpy 来处理字节转换
    return result;
}

int main() {
    uint16_t high16 = 0x42F0;  // 高 16 位数据
    uint16_t low16 = 0x0000;   // 低 16 位数据

    float combinedFloat = combine16ToFloat(high16, low16);
    printf("Combined float: %f\n", combinedFloat);  // 打印合成后的浮点数
    return 0;
}

解释

  1. 合并 16 位数据

    • ((uint32_t)high16 << 16)high16 移动到高 16 位。
    • | low16low16 放到低 16 位。
    • 这样就得到了一个 32 位的整数 combined
  2. 转换为 float

    • 使用 memcpycombined 的字节内容拷贝到 float 类型的变量 result 中。这样做是因为 floatuint32_t 在内存中的表示方式不同,直接赋值可能导致数据不正确。

    • memcpy 是一种直接的字节拷贝方式,确保字节顺序没有变化。

相关推荐
低代码布道师19 分钟前
家政预约小程序12服务详情
开发语言·javascript·低代码·小程序
飞舞花下23 分钟前
一、0-1搭建springboot+vue3前后端分离-前端项目创建
前端
Z小明39 分钟前
JavaScript 对象操作方法详解
前端·javascript
逝水流光41 分钟前
Canvas系列(19):实战-五彩纸屑
前端·canvas
茂林QAQ44 分钟前
让代码像是打字一样显示在页面上
前端
脏脏a1 小时前
深度探索 C 语言操作符:从基础到实战应用
c语言·操作符
前端老实人灬1 小时前
解决浏览器播放音频声音,没交互前不播放问题
javascript·音视频·交互
枫叶丹41 小时前
【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(四) -> 常见组件(一)
前端·javascript·华为·华为云·harmonyos
dal118网工任子仪2 小时前
102,【2】buuctf web [第二章 web进阶]XSS闯关
前端·xss
神仙别闹2 小时前
基于 Java 的 C 语言编译器
java·c语言·开发语言