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

相关推荐
SuperEugene15 分钟前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
极梦网络无忧39 分钟前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
Predestination王瀞潞1 小时前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
爱学习的程序媛1 小时前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr1 小时前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹1 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang1 小时前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端
C羊驼1 小时前
C语言学习笔记(十一):数据在内存中的存储
c语言·经验分享·笔记·学习
雪碧聊技术1 小时前
前端vue代码架子搭建
前端·javascript·vue.js·前端项目代码框架搭建
爱学习的程序媛1 小时前
【Web前端】前端用户体验优化全攻略
前端·ui·交互·web·ux·用户体验