计算机在底层使用的是二进制补码进行运算。

计算规则:

  正数的原码、反码、补码是其二进制本身。

  负数的原码首先计算其二进制数,然后最高位使用1表示负数,反码是最高位不变其它位取反,补码是在反码的基础上进行+1操作。

  System.out.println( 8 >> 1);//正数进行右移位运算

8的二进制是 0000 0000 0000 0000 0000 0000 0000 1000,进行右移1位得到二进制0000 0000 0000 0000 0000 0000 0000 0100,然后转成二进制是4
  以此类推

   /*   1000
         *   0100    4    右移1位
         *   0010    2    右移2位
         *   0001    1    右移3位
         *   0000    0    右移4位
         * */

System.out.println( -8 >> 1);//负数进行右移位运算  (右移高位补1)

-8的二进制是1000 0000 0000 0000 0000 0000 0000 1000,这里最高位1表示是负数

  /*
         * 1000 0000 0000 0000 0000 0000 0000 1000 原码
         * 1111 1111 1111 1111 1111 1111 1111 0111 反码
         *                                       1
         * 1111 1111 1111 1111 1111 1111 1111 1000   补码
         * 1 1111 1111 1111 1111 1111 1111 1111 100 位运算得到的是补码然后转到原码
         * 1 0000 0000 0000 0000 0000 0000 0000 011
         *                                           1
         * 1 0000 0000 0000 0000 0000 0000 0000 100 -4  原码
         * */

   System.out.println(8<<2);//正数进行左移位运算

/*

   * 0000 0000 0000 0000 0000 0000 0000 1000  原码

   * 0000 0000 0000 0000 0000 0000 0010 0000 位运算 32

   */

   System.out.println(-8<<2);//负数进行左移位运算(左移地位补0)
        /* 1000 0000 0000 0000 0000 0000 0000 1000   -8的原码
         * 1111 1111 1111 1111 1111 1111 1111 0111   反码
         * 1111 1111 1111 1111 1111 1111 1111 1000   补码
         * 11 1111 1111 1111 1111 1111 1111 100000  位运算
         * 10 0000 0000 0000 0000 0000 0000 011111 位运算之后补码
         * 10 0000 0000 0000 0000 0000 0000 100000 原码
         *  -32
         * */

  System.out.println(-9>>>2);无符号运算,高位进行补0,低位舍去
        /*    
         * 1000 0000 0000 0000 0000 0000 0000 1001    原码

    * 1111 1111 1111 1111 1111 1111 1111 0110 反码
         * 1111 1111 1111 1111 1111 1111 1111 0111    补码
         * 001111 1111 1111 1111 1111 1111 1111 01    移位   (移位得到的是正数,所以补码就是其本身)
         * */

java位运算和无符号运算的更多相关文章

  1. JavaScript 32位整型无符号操作

    在 JavaScript 中,所有整数字变量默认都是有符号整数,这意味着什么呢? 有符号整数使用 31 位表示整数的数值,用第 32 位表示整数的符号,0 表示正数,1 表示负数. 数值范围从 -2^ ...

  2. java位运算

    Java的位运算(bitwise operators)直接对整数类型的位进行操作,这些整数类型包括long.int.short.char和 byte,位运算符具体如下表: 运算符 说明 << ...

  3. java位运算,逻辑运算符

    位运算逻辑运算符包括: 与(&),非(~),或(|),异或(^). &:  条件1&条件2  ,只有条件1和条件2都满足, 整个表达式才为真true,  只要有1个为false ...

  4. Java 位运算超全面总结

    1.原码.反码.补码 关于原码.反码.补码的相关知识作者不打算在这里长篇大论,相关知识已有别的大佬总结很好了,还请老铁自行 Google,不过有篇知乎回答是作者学编程以来见过对相关知识最通俗易懂,生动 ...

  5. Java位运算总结

    关于位运算,以前也见过,搜过,当时会用了,过后就忘了,今天好好学习一遍,然后整理一下. Java中的位运算,涉及到计算机的二进制,位用bit表示,1Byte=8bit,根据各种基本数据类型占用的字节空 ...

  6. Java 与无符号那些事儿

    最近在使用 Java 作为 WebSocket 客户端连接 Node.js 的 WebSocket 服务器的时候,由于使用的客户端库比较老,所以遇到了字节符号的问题,上网查了一下,看到这篇文章写的很有 ...

  7. 【Java基础】基本类型与运算【重要】

    0.   Java基本数据类型 Java的位运算(bitwise operators)直接对整数类型的位进行操作,这些整数类型包括long.int.short.char和 byte,位运算符具体如下表 ...

  8. unsigned无符号、有符号类型的符号拓展

    先看一段代码 #include <stdio.h> main(){ unsigned ; char b = a; printf("%d %d",a,b); ; } a输 ...

  9. [JAVA]移位运算(左移<<,右移>>和无符号右移>>>)

    一.背景知识 整数在内存中是以二进制的形式存在的,而且存的是该整数的补码.最高位代表符号位,正数为0,负数为1 正数的补码是其二进制本身,负数的补码则是 符号位保持1不变,其他位按位取反再加1,+0和 ...

随机推荐

  1. ie6中兼容性问题总结

    针对firefox ie6 ie7 ie8的css样式中的line-height属性,以前我们大部分都是用!important来hack,对于ie6和firefox测试可以正常显示,但是ie7以上对! ...

  2. jenkins执行selenium自动化测试浏览器不显示解决方法

    因为jenkins是用windows installer 安装成 windows的服务了,那么jenkins是一个后台服务,所以跑selium cases 的时候不显示浏览器 解决办法:Step 1. ...

  3. [转]GDB调试基础

    一.gdb常用命令: 命令 描述 backtrace(或bt) 查看各级函数调用及参数 finish 连续运行到当前函数返回为止,然后停下来等待命令 frame(或f) 帧编号 选择栈帧 info(或 ...

  4. hdu 1272 使用set和并查集

    http://acm.hdu.edu.cn/showproblem.php?pid=1272 这道题就是求图是不是连通无环,我觉得其实就是看看图是不是一棵最小生成树. 所以要是图满足条件,就必然有n个 ...

  5. spring-data-jpa实体类继承抽象类如何映射父类的属性到数据库

    在抽象父类上加上注解@MappedSuperclass @MappedSuperclass public class Pet { private Integer id;//id private Str ...

  6. HDU - 4725_The Shortest Path in Nya Graph

    The Shortest Path in Nya Graph Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (J ...

  7. 洛谷4178 BZOJ1468 Tree题解点分治

    点分治的入门练习. 题目链接 BZOJ的链接(权限题) 关于点分治的思想我就不再重复了,这里重点说一下如何判重. 我们来看上图,假设我们去除了1节点,求出d[2]=1,d[3]=d[4]=2 假设k为 ...

  8. js错误处理Try-catch和throw

    1.try-catch语句   Try{ //可能会导致错误的代码 }catch(error){ //在错误发生时怎么处理 } 例如: try{ window.someNonexistentFunct ...

  9. Spring Boot错误——SpringBoot 2.0 报错: Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.

    背景 使用Spring Cloud搭建微服务,服务的注册与发现(Eureka)项目启动时报错,错误如下 *************************** APPLICATION FAILED T ...

  10. Libev源码分析04:Libev中的相对时间定时器

    Libev中的超时监视器ev_timer,就是简单的相对时间定时器,它会在给定的时间点触发超时事件,还可以在固定的时间间隔之后再次触发超时事件. 所谓的相对时间,指的是如果你注册了一个1小时的超时事件 ...