C++ 原码,反码,补码 与移位操作符

本文通过实例解析了计算机中整数的原码、反码、补码概念及其转换过程,并介绍了左移与右移两种移位操作符的工作原理。文中详细解释了-1的32位二进制表示,以及通过移位操作如何得到新的数值。

//原码,反码,补码 与移位操作符
int main() {
    int a = -1;
    //整形的二进制表现有:原码,反码,补码
    // 存储到内存的是补码
    //例如 -1
    // 32位bit 的第一位是符号位:正数符号位是0,负数符号位是1
    // 10000000 00000000 00000000 00000001 原码 
    // 11111111 11111111 11111111 11111110 反码 (原码->反码,符号位不变,其他位按位取反)
    // 11111111 11111111 11111111 11111111 补码    (反码+1)

    int b = a << 1; //向左移一位,右边补 0 ,           11111111 11111111 11111111 11111110  =  -2
    int d = a >> 1; //向右移一位,左边补符号位  ,  11111111 11111111 11111111 11111111 = -1

    printf("%d",b);

    return 0;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值