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?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)