计算机基础---反码,补码与运算符

本文介绍了计算机中负数的补码表示法,并通过实例解析了-1L的二进制表示。讨论了左移操作符<<和异或运算符^在Java中的应用,详细解释了计算表达式-1L ^ (-1L << 5)得到31的过程,涉及原码、反码、补码及逻辑运算知识。
摘要由CSDN通过智能技术生成

最近在研究分布式生成全局唯一ID算法Snowflake时遇到一个很有意思的数据

long x = -1L ^ (-1L << 5);

这个x的值究竟是多少呢?答案是31

现在就让我们一起探讨一下这个问题。

首先 long 这一基本数据类型为长整型,在Java里占用64位二进制,所以对于-1L 我们可以用以下的二进制表示,其中第一位为符号位,符号位为1则是负数,为0则为正数,此处将符号位脱离开,这样便于观察。

-1L = 1 1111111 11111111 11111111 11111111 11111111 11111111 11111111 11111111

如何得到-1L的二进制呢?我们需要知道计算机计数的方式,这儿就涉及到所谓的补码,反码概念。

在计算机中,负数的二进制是使用补码表示的。如果在Java中我们要表示 int 型(具有32位二进制)的 1,我们的表示如下:

1 = 0 0000000 00000000 00000000 00000001

那如何表示-1呢?我们都知道 1 + (-1)= 0,那么在二进制中,可以这样表示等式:

  0 0000000 00000000 00000000 00000001 // 1的二进制表示
+ x xxxxxxx xxxxxxxx xxxxxx
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值