一大波黑科技c
1.补码:
在电脑中2进制都通过补码储存,因此补码对于电脑的运算和程序员的使用很重要,补码是原码取反码再加1,正数的的反码和补码和原码一样。
2.隐式转换:
在电脑运算中,有很多隐式转换问题,都是向字节大的地方转换的,比如short和int的运算中都是转换为int类型计算。
3.符号位扩展:
…
int _tmain(int argc, _TCHAR* argv[])
{
char b = 0x83;
short s1 = (short)b;
short s2 = (short)(b&0xff);
printf("s1 = %d\n", s1);
printf("s2 = %d\n", s2);
return 0;
}
…
char占一个字节,short占两个字节,在转换时,将16进制码转换成2进制,然后字节多的看第一位是0则多出来的位全部补0,是1就全部补1。然后计算机当做补码读取,则实际表示的10进制数,还需转换为10进制。
如0x83的二进制是10000011,因为的一位是0,扩展时在原码上补1,则补为
1111111110000011,计算机当做补码读取,则原码为1000000001111101,是-125。
4. 32位与64位的区别:
占字节
32位 64位
int 4 4
long 4 8
long long 8 8
5.用处不大的位域运算:
struct bs
{int a:8;int b:2;int c:6;};
定义方式,上方的常量表示分给其:前变量的位数,给abc分别赋值以后,其分别用二进制储存到其分配位数中,不足补0,连续的同类型数据会被连续储存,只有当类型对于字节数对应位数的剩余量不足时,会跳到下一个字节对应位数中分配位数,前字节中位数剩余均补0。出现不同类型时,字节对齐最大字节字符类型,类型变换处直接跳到下一个字节对应位数表中分配位数格,前一个剩余位数格全部补0,最后组成的连续二进制数转换为的10进制表示中国结构体代表的数大小。