对于C语言中float、uint32、uint16、int32、int16的思考

工作中遇到这些格式之间的转换,后面发现部分之间转换存在精度损失,故此记录;

1:   32位float想要转32uint

uint32 uint32_a = 0;

float32 float32_b = 314.5;

uint32_a = *(uint32 *)(&float32_b);//不能直接uint32_a = (float32)float32_b;

2:   情景是从寄存器上读到16位数据,存放在uint16数组中,用到接下来运算中要当作int16类型与float32位数进行运算,并得到float32位结果数据,此时疑惑该如何转换?uint16转int16?uint16转float32?是地址转还是强制转?

请教老师傅得到的解答是:可以直接强转为int16然后参与运算,后续和float32运算中会隐性转换为float32;也可以强转为float32直接参与运算,先采纳,后续慢慢吸收。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将C语言的uint8类型转换int8类型,可以使用类型转换操作符进行操作。具体的转换方法是将uint8类型的变量赋值给int8类型的变量。 示例代码如下: ```c uint8_t uint8_value = 200; int8_t int8_value = (int8_t)uint8_value; ``` 在这个例子,我们先定义了一个uint8_t类型的变量uint8_value,并初始化为200。然后,我们使用类型转换操作符将uint8_value转换int8_t类型,并将结果赋值给int8_value。 请注意,由于int8_t是有符号类型,而uint8_t是无符号类型,所以可能存在溢出的情况。在进行类型转换时,需要确保转换后的数值在int8_t类型的取值范围内。 提供了一个C#语言的示例代码,但不适用于本问题。 提供了一个关于向std::vector添加unsigned int类型的数据的函数,与本问题无关。 提供了一个将用户输入的字符串转换为UInt16类型的示例代码,但不适用于本问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C#如何将uint16转为int16](https://blog.csdn.net/gongyejishuhulian/article/details/119822822)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [float uint32 uint16 转为uint8](https://blog.csdn.net/weixin_30175731/article/details/117177352)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值