zoukankan      html  css  js  c++  java
  • java.lang.Integer.MAX_VALUE;这是什么意思?

    这个是Integer类中的一个int类型的常量MAX_VALUE
    它代表int所能表示的最大值 0x7FFFFFFF

    相对应的是Integer类中的另一个常量MIN_VALUE
    它代表int所能表示的最小值 0x80000000

    整型的其他的子型也可以 byte short long?

    基本类型之间不存在子型和父型,只是范围不同,
    小范围转换为大范围可以直接转换
    大范围转换小范围需要强制转换符号,
    例如:
    long lv=123456;
    int v=(int) lv;

    数字基本类型都有对应的类及最大最小值常量
    Byte.MAX_VALUE =0x7F
    Byte.MIN_VALUE =0x80

    Short.MAX_VALUE =0x7FFF
    Short.MIN_VALUE =0x8000

    Integer.MAX_VALUE =0x7FFFFFFF
    Integer.MIN_VALUE =0x80000000

    Long.MAX_VALUE =0x7FFFFFFFFFFFFFFF
    Long.MIN_VALUE =0x80000000000000000

    java源代码:
    Integer.MAX_VALUE经常会在集合中用到,对这个概念一直没有深究过,查看一下源码。

    一个常数,持有了int类型数最小值,-2^31次方,-2147483648。负21亿多。

    /**

    * A constant holding the minimum value an {@code int} can

    * have, -2<sup>31</sup>.

    */

    @Native public static final int MIN_VALUE = 0x80000000;

     

    一个常数,持有了int类型数的最大值,2^31次方,2147483648,正21亿多

    /**

    * A constant holding the maximum value an {@code int} can

    * have, 2<sup>31</sup>-1.

    */

    @Native public static final int MAX_VALUE = 0x7fffffff;

     

    解释:
    1、0x80000000
    0x表示16进制

    80000000一共8位16进制,也就是32位的2进制,2进制写法位数太多了,不展开写了,这也是为什么用16进制表示的原因。

    1000 后面28个0,前面1表示负数,后面的27个0,这个应该是补码,那就是-1,会得到27个1,然后再求反码,27个0,纳尼???

    因为这个数达到了32位二进制的上限,所以我们不会再去按照-1,再反码的方式求真正的值,直接按照原码的负数计算即可。也就是-2^31次方。

     

    2、0x7fffffff
    展开就是0111后面28个1,也就是一共31个1的整数,2^31 - 1

     

    3、MAX_VALUE + 1 == MIN_VALUE
    这他妈就好玩了,0111 1111 1111 1111 1111 1111 1111 1111+1 = 1000 0000 0000 0000 0000 0000 0000 0000 没毛病。

    或者这么想,我们把计算机的“模”从中间剖开,负数逆时针,正数顺时针,正数从0到6点钟,包括0不包括6点钟,负数从0到6点钟,不包括0,包括6点钟,MAX_VALUE再往前+1,就是MIN_VALUE




    Integer.MIN_VALUE,即-2147483648,二进制位如下:

     
    1000 0000 0000 0000 0000 0000 0000 0000

     

    在计算机的运算中,“-”(前缀)运算表示各二制位取反再加1,也就是说 b = -a 在计算机内部是 b = ~a + 1 这样处理的,所以上面的位就变成了:

     

       1000 0000 0000 0000 0000 0000 0000 0000 Integer.MIN_VALUE

    取反 0111 1111 1111 1111 1111 1111 1111 1111 (取反之后变成了Integer.MAX_VALUE)

    加1 1000 0000 0000 0000 0000 0000 0000 0000 -Integer.MIN_VALUE(与原来的结果一样)


  • 相关阅读:
    LeetCode-079-单词搜索
    awk学习笔记
    Python实现排列组合算法
    python模拟登录人人
    Python的SQLite数据库使用方法
    C语言排序算法——插入排序算法
    C语言排序算法——简单选择排序算法
    C语言排序算法——冒泡排序算法
    Python学习——python的函数参数传递
    Python学习——实现secure copy功能
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/10997998.html
Copyright © 2011-2022 走看看