1.有符号int与无符号int比较
#define TOTOL_ELEMENTS (sizeof(a) / sizeof(a[0]) );
int main()
{
int a[] = {23,24,34};
int d = -1;
if(d<=TOTOL_ELEMENTS)
printf("TRUE\n");
else
printf("FLASE\n");
return 0;
}
//结果是FLASE而不是TRUE
结果分析:sizeof() 返回的是无符号整型,因此上述代码中TOTOL_ELEMENTS 的值是unsigned int类型。与 if 语句中signed int 型的 d 比较,signed int 型会被转化成unsigned int 型变量。
-1会转化成一个非常巨大的数---65535
*************************************************************
原码、反码、补码:
原码:二进制定点表示法,即最高位是符号位。0为正,1为负。
反码:正数的反码与原码相同;负数的反码是对其原码逐位去反,符号位除外。
补码:正数的补码与原码相同;负数的补码是在其反码末位上加1。
在计算机中,数值一律用补码存储,因为其能将符号位与数值统一处理。
********************************************************************
以int型的-1为例:
-1是负数,原码为 10000000 00000001 (int为2字节)
反码为 11111111 11111110
补码为 11111111 11111111
那么有符号怎么转化成无符号的呢?直接取绝对值的补码就行了。算术解决:|a|*2-|a| = 无符号的a
int a = -1;
(unsigned int)a= ?
(1)先取-1 的绝对值1的原码 00000000 00000001
(2)将其转化为反码 01111111 11111110
(3)对所求的数+1得到补码。补码就是无符号char的a值,转换为十进制数为65535
所以(unsigned int)a=65535;
另外,注意:printf函数输出的是无符号的值!!
2.位域变量 的符号问题
#include <stdio.h>
struct data
{<