zoukankan      html  css  js  c++  java
  • java 整型

    byte(1字节)、short(2字节)、int(4字节)、long(16字节)

    java中前缀加上0b或者0B就可以写二进制数,前缀加上0就可以写八进制数,前缀加上0x或者0X就可以写十六进制数

    一个字节是8位,最高位是符号位,最高位为0则是正数。最高位为1则是负数,

    先了解原码、反码和补码的表示规则:

    0的表示:

                   原码:有正零和负零之分,[+0]补=0000 0000,[-0]补=1000 0000;

                   反码:同样有两种表示方法,[+0]反=0000 0000 ,[-0]反=1111 1111;

                   补码:零只有一种表示方法,不分正负,[0]补=0000 0000;

    所以可以得出取值范围(因为0和其他一些问题,采用补码,了解详情https://blog.csdn.net/ai_yue/article/details/82777806):

    byte:最大0111 1111 为 127 最小 1000 0000 为 -128

    short:0111 1111 1111 1111 为 32767  1000 0000 0000 0000 为 -32768

    int:0111 1111 1111 1111 1111 1111 1111 1111 为  2147483647

           1000 0000 0000 0000 0000 0000 0000 0000 为 -2147483648

    long: 9223372036854775807~-9223372036854775808

    int和Integer问题:

    Integer.valueOf(int i)方法,在传入i的值不在-128和127之间时,便new出一个新的Integer对象;如果范围在-128和127之间,则直接从IntegerCache缓存中取出i  对应的Integer对象。所以

            Integer i = Integer.valueOf(127);
    	Integer j = 127;
    	System.out.println(i == j);  //true
    	
    	
    	Integer x = Integer.valueOf(128);
    	Integer y = 128;
    	System.out.println(x == y);  //false
    

      

  • 相关阅读:
    正则表达式
    数据结构与算法-串
    数据结构与算法-优先级队列
    数据结构与算法-词典
    数据结构与算法-高级搜索树
    数据结构与算法-二叉搜索树
    数据结构与算法-图
    数据结构与算法-二叉树
    数据结构与算法-栈与队列
    数据结构与算法-列表
  • 原文地址:https://www.cnblogs.com/guuyoog/p/11125650.html
Copyright © 2011-2022 走看看