为什么普通类型的bool和int8_t在C中是int32_t?

为什么普通类型的bool和int8_t在C中是int32_t?,第1张

概述我很好奇C的内置bool类型的一些行为.据我所知, std::common_type使用隐式可转换性来确定通用类型.我会期望一个表达式与bool和另一种类型会导致bool转换为该类型.例如,我可以看到bool float – > float和bool double – >双.但是,bool int8_t – > int32_t和bool int16_t – > int32_t.为什么会这样? 简答 我很好奇C的内置bool类型的一些行为.据我所知,std::common_type使用隐式可转换性来确定通用类型.我会期望一个表达式与bool和另一种类型会导致bool转换为该类型.例如,我可以看到bool float – > float和bool double – >双.但是,bool int8_t – > int32_t和bool int16_t – > int32_t.为什么会这样?解决方法 简答:积分推广.

在数值运算中,如果所有可能的值适合于int,则将小整数类型(包括bool,char,unsigned char,signed char,short,unsigned short等)提升为int,否则将其提升为unsigned int.

在大多数机器上,int32_t与int相同.在bool int8_t或bool int16_t的情况下,两者都被提升为int.

总结

以上是内存溢出为你收集整理的为什么普通类型的bool和int8_t在C中是int32_t?全部内容,希望文章能够帮你解决为什么普通类型的bool和int8_t在C中是int32_t?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1234510.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存