Java位运算符

  • Java位运算符:Java的位运算符是把数字看作二进制来进行计算的。

    1. 按位与(&):如果存在两个二进制位都为1,则该位结果为1,否则为0
    2. 按位或(|):只要一个为1,则为1,否则为0
    3. 按位异或(^):两个二进制位相异为1,否则为0
    4. 取反(~):对数据的每个二进制位取反,即把1变0,把0变1
    5. 左移动(<<):运算数的各二进制位全部向左移动若干位,即乘以2的若干次方
    6. 右移动(>>):运算数的各二进制位全部向右移动若干位,即整除以2的若干次方

    异或的数学规则
    运算律:x^x=0, x^0=x
    交换律:x^y ^z =x^z ^y

  • 实际例子

    int a = 60; #60的二进制为 0011 1100
    int b = 13; #13的二进制为 0000 1101
    int c = 0;
    
    a&b: #结果为 0000 1100
    a|b: #结果为 0011 1101
    a^b: #结果为 0011 0001
     -a: #结果为 1100 0011
    a<<3: #结果为 1111 0000 0
    a>>3: #结果为 0000 0111
    
    System.out.println("二进制输出:":+Integer.toBinaryString(a&b));
    System.out.println("八进制输出:"+Integer.toOctalString(a));
    System.out.println("十六进制输出:"+Integer.toHexString(a));
    

负数的二进制表示
负数的二进制表示形式在计算机中,是以其正值的补码形式表示的。

  • 原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。如:00000000 00000000 00000000 00000101 是 5的 原码。
  • 反码:将二进制数(原码)按位取反(1变0,0变1),得到的新二进制数称为原二进制数的反码。如:将00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。
  • 补码:所得反码加1。也就是说要得到一个数的补码,先得到反码再加1。

看看整数-1在计算机中如何表示。

  1. 先取1的原码:00000000 00000000 00000000 00000001
  2. 得反码:11111111 11111111 11111111 11111110
  3. 得补码:11111111 11111111 11111111 11111111
    可见-1在计算机里面用二进制表达就是全1,16进制为:0xffffffff,根据-1的补码计算出实际十进制表示为:0xffffffff - 2**32
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在学习源码中,发现有大量使用位运算符,这样做的目的是为了节约内存开销和加快计算效率。 位运算符,这个"位"代表这什...
    杨杰C阅读 1,273评论 0 0
  • 位运算符 位运算符主要针对两个二进制数的位进行逻辑运算,它包括:与(&)、或(|)、非(~)、异或(^)**运算规...
    深情不及酒伴阅读 1,117评论 0 1
  • Java中所支持的位运算符一共有7个 &:按位与。当两位同时为1时才返回1。 |:按位或。只要有一位为1即可返回1...
    小小的coder阅读 404评论 0 0
  • 一、位运算 二、位移运算 三、二进制数 以Java中最常使用的int类型为例(32位)。 ㈠ 符号位 二进制数最左...
    幽蓝鑫晨阅读 834评论 0 0
  • 中午去巾石姨妈家吃饭,她孙子(第三胎)办满月酒。我们去的比较晚,大家都吃好饭了,姨妈一家帮我们收拾好一桌碗筷吃饭好...
    娟娟_52c0阅读 153评论 0 0