大佬教程收集整理的这篇文章主要介绍了c – 有符号位字段表示,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
#include <stdio.h> #include <stdlib.h> union { struct { int bit:1; } field; int rep; } n; int main() { int c,k; n.field.bit=1; for (c = 31; c >= 0; c--) { k = n.rep >> c; if (k & 1) printf("1"); else printf("0"); } printf("\n %d \n",n.field.bit); return 0; }
输出是:
00000000000000000000000000000001
-1
在那种情况下,为什么我的位字段的值是-1,当我使用signed int而不是unsigned时,它总是一个负数?
@H_801_2@
在您的情况下,int指定与signed int相同的类型;这是the default in GCC:
然后是实现定义有符号数是一个补码还是二进制补码 – 如果它们是一个补码,则可以存储在1位中的唯一值是符号位,因此为0;所以一位的有符号位字段在一个补码上没有意义.但是,您的系统使用2的补码 – 例如what GCC always uses:
因此比特值1和0用带符号的二进制补码来解释:前者有符号位设置,所以它是负(-1)而后者没有符号位设置所以它是非负的(0).
因此,对于2比特的有符号比特字段,2的补码机器上的可能比特模式及其整数值是
> 00 – 具有int值0
> 01 – 具有int值1
> 10 – 具有int值-2
> 11 – 具有int值-1
在N比特字段中,最小有符号数是-2 ^(n-1),最大值是2 ^(n-1)-1.
现在,当对秩小于int的有符号整数操作数执行算术运算时,它首先被转换为int,因此值-1被符号扩展为全宽度int;默认参数促销也是如此;将值传递给printf时,该值将符号扩展为(全角)int.
因此,如果您希望从一位位域获得合理的值,请使用无符号位:1;或者,如果将其理解为布尔标志,则_Bool位:1;
@H_801_2@ @H_801_2@以上是大佬教程为你收集整理的c – 有符号位字段表示全部内容,希望文章能够帮你解决c – 有符号位字段表示所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。