Integer.toHexString(int i)的理解

Integer.toHexString(int i),这个方法是Integer类提供的一个将传入的int类型转成(无符号)16进制字符串的方法(我测了 二进制十进制都可以,本文主要记录十进制)
1.首先它调用了toUnsignedString0(i, 4)这个方法

 public static String toHexString(int i) {
 //因为一个十六进制,占用四个字节 所以这里传4
        return toUnsignedString0(i, 4);
    }

2.我们通过点进去发现

private static String toUnsignedString0(int val, int shift) {
        // assert shift > 0 && shift <=5 : "Illegal shift value";
        //通过调用numberOfLeadingZeros方法 获取val左边连续0的个数,得到val的实际填充位数
        int mag = Integer.SIZE - Integer.numberOfLeadingZeros(val);
        //通过实际填充位数,计算chars的值,当val值为0时,chars=1,因为是十六进制所以 (mag+3)/4可以得到十六进制数的位数
        int chars = Math.max(((mag + (shift - 1)) / shift), 1);
        //定义一个长度为chars的插入数组,用来存放十六进制的字符
        char[] buf = new char[chars];

	//通过这个方法给buf数组赋值,完成转换工作
        formatUnsignedInt(val, shift, buf, 0, chars);

        // Use special constructor which takes over "buf".
        return new String(buf, true);
    }

接下来我们讲一讲numberOfLeadingZeros()和formatUnsignedInt()这两个方法
2.1 Integer.numberOfLeadingZeros(val)
这个方法返回这个数值左边连续不为0的个数

public static int numberOfLeadingZeros(int i) {
    // 当i=0 32个字节全是0 直接返回32
    if (i == 0)
        return 32;
    int n = 1;
    //当i无符号右移16位=0时,n=17,i等于i左移十六位,否则直接下一步
    if (i >>> 16 == 0) { n += 16; i <<= 16; }
     //当i无符号右移24位=0时,n=n+8,i等于i左移8位,否则直接下一步,剩下同理
    if (i >>> 24 == 0) { n +=  8; i <<=  8; }
    if (i >>> 28 == 0) { n +=  4; i <<=  4; }
    if (i >>> 30 == 0) { n +=  2; i <<=  2; }
    //此时i的前31位都是有值的,n=n-(i的第三十二位的值)即可得到左边连续为0的数量
    n -= i >>> 31;
    return n;
}

2.2 formatUnsignedInt(int val, int shift, char[] buf, int offset, int len)
这个方法是把val 转换成十六进制的字符 按顺序放到 buf数组中

 static int formatUnsignedInt(int val, int shift(4, char[] buf, int offset(0, int len(buf数组的长度)) {
        int charPos = len;
        int radix = 1 << shift;//16
        int mask = radix - 1;//15
        do {
        //获取val低四位与15取交集记为num,即它本身。把buf数组的最后一个值设为digits 索引为num的字符,因为低四位最大值为15所以最多取到f
            buf[offset + --charPos] = Integer.digits[val & mask];
            //val左移四位 ,然后重复进行上述操作,不断取出低四位的值,把它对应的字符放到buf中去
            val >>>= shift;
        } while (val != 0 && charPos > 0);
    
        return charPos;
    }

 final static char[] digits = {
        '0' , '1' , '2' , '3' , '4' , '5' ,
        '6' , '7' , '8' , '9' , 'a' , 'b' ,
        'c' , 'd' , 'e' , 'f' , 'g' , 'h' ,
        'i' , 'j' , 'k' , 'l' , 'm' , 'n' ,
        'o' , 'p' , 'q' , 'r' , 's' , 't' ,
        'u' , 'v' , 'w' , 'x' , 'y' , 'z'
    };
  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值