12号c总结

一大波黑科技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进制表示中国结构体代表的数大小。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值