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

相关推荐
zqmattack1 分钟前
XML外部实体注入与修复方案
java·javascript·安全
李剑一1 分钟前
别再用input file做上传组件了
前端
Jackson_Mseven1 分钟前
🎯 面试官:React 并发更新怎么调度的?我:Lane 就是调度界的 bitmap!
前端·react.js·面试
拾光拾趣录1 分钟前
前端响应式布局:手把手实现智能PX转REM
前端·javascript·css
krysliang2 分钟前
qiankun使用教程(从项目搭建到容器化部署)
前端·架构
遂心_3 分钟前
#React Router Dom 入门:构建现代单页面应用的前端路由方案
前端·javascript·react.js
真夜4 分钟前
记录van-rate组件输入图片打包后无效问题
前端·vue.js·typescript
幽你一默4 分钟前
Android高效列表更新:DiffUtils深度解析
前端
雲墨款哥4 分钟前
Vue3 图片放大镜组件优化实践:用 transform 替代 relative 定位 & watchThrottled 优化性能
前端·vue.js
爱编程的喵8 分钟前
React Hooks + 自定义Hooks 打造现代化 Todo 应用:记事本
前端·react.js