zoukankan      html  css  js  c++  java
  • Java 十进制和十六制之间的转化(负数的处理)

    原文: http://www.cnblogs.com/literoad/archive/2013/01/25/2875908.html

    在一些情况下,我们需要将数字在十进制和十六制下互相转化。

    在Java中将十进制转化成十六进制非常的简单。

    int var = 324;
    String hex = Integer.toHexString(var);
    
    
    long lvar = 3243143432134L;
    String lhex = Long.toHexString(lvar);
     
    这样就可以得16进制的字符串了。当要从十六进制转化成十进制的时候也很方便:
    Integer.parseInt(hex, 16);
    Long.parseLong(hex, 16);
     
    当int和long变量的值都是正数的时候,这样做一点问题都没问题,但当int和long变量的值为负数的时候,问题就出现了:
    int var = -23243;
    String hex = Integer.toHexString(var);
    Integer.parseInt(hex, 16);
    这时会报出Exception:

    Exception in thread "main" java.lang.NumberFormatException: For input string: "ffffa535"
        at java.lang.NumberFormatException.forInputString(NumberFormatException.java:48)
        at java.lang.Integer.parseInt(Integer.java:459)
        at demo.Main.main(Main.java:10)

    这是为什么呢? 问题就在于Integer.parseInteger的时候,会将传入十六进制数字一致认为成正数,所以这时候表示负数的十六进制字符串所表示的数字就超出了Integer所能表示的数字范围,所以会报出NumberFormatException, 同时的问题也会现在Long.parseLong身上。

    那么如何才解决这个问题呢?这时候的解决方案就是BigInteger.

    BigInteger bi = new BigInteger(hex, 16);

    通过BigInteger.intValue();和 BigInteger.longValue(); 得到你所需要的int或long型值。

  • 相关阅读:
    卢卡斯定理算法模板
    求组合数的O(n^2)和O(n)解法及模板
    求逆元的方法及模板
    扩展欧基里德算法模板
    牛客练习赛43-F(简单容斥)
    容斥原理
    牛客网练习赛43-C(图论)
    折半搜索
    枚举+树状数组(经典)
    思维并查集/网络流和二分
  • 原文地址:https://www.cnblogs.com/jiftle/p/7127996.html
Copyright © 2011-2022 走看看