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 是一种直接的字节拷贝方式,确保字节顺序没有变化。

相关推荐
pe7er2 小时前
window管理开发环境篇 - 持续更新
前端·后端
We་ct3 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
陈随易7 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星7 小时前
javascript之事件代理/事件委托
前端
陈随易8 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
代码中介商10 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
想成为优秀工程师的爸爸10 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
里欧跑得慢10 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒11 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei11 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js