Integer源码之实现方法

1. Integer.bitCount

public static int bitCount(int i) {
        // HD, Figure 5-2
        i = i - ( (i >>> 1) & 0x55555555  );
        i = (i & 0x33333333) + ((i >>> 2) & 0x33333333);
        i = (i + (i >>> 4)) & 0x0f0f0f0f;
        i = i + (i >>> 8);
        i = i + (i >>> 16);
        return i & 0x3f;
    }

他表示的是计算int类型转化为二进制之后1的个数,举个例子,5用二进制表示为101,那么就返回2,表示有2个1,8用二进制表示是1000,就会返回1,表示有一个1.但是这个方法用的非常妙,直接看可能不是太明白,如果把上面的数字转化成二进制可能就会明白很多,0x55555555用二进制表示就是……01010101(1个0,1个1循环,总共是32位),0x33333333用二进制表示就是……00110011(2个0,2个1循环,总共32位),0x0f0f0f0f用二进制表示就是……0000111100001111(4个0,4个1循环,总共32位),看到这里可能就会稍微有点明白,其实他的原理就是每两

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`Integer.parseInt()` 函数的具体实现如下: ```java public static int parseInt(String s) throws NumberFormatException { return parseInt(s,10); } public static int parseInt(String s, int radix) throws NumberFormatException { if (s == null) { throw new NumberFormatException("null"); } if (radix < Character.MIN_RADIX) { throw new NumberFormatException("radix " + radix + " less than Character.MIN_RADIX"); } if (radix > Character.MAX_RADIX) { throw new NumberFormatException("radix " + radix + " greater than Character.MAX_RADIX"); } int result = 0; boolean negative = false; int i = 0, len = s.length(); int limit = -Integer.MAX_VALUE; int multmin; int digit; if (len > 0) { char firstChar = s.charAt(0); if (firstChar < '0') { //处理负数 if (firstChar == '-') { negative = true; limit = Integer.MIN_VALUE; } else if (firstChar != '+') throw NumberFormatException.forInputString(s); if (len == 1) // 如果只有一个符号,则抛出异常 throw NumberFormatException.forInputString(s); i++; } multmin = limit / radix; while (i < len) { digit = Character.digit(s.charAt(i++),radix); if (digit < 0) // 如果字符不是数字,则抛出异常 throw NumberFormatException.forInputString(s); if (result < multmin) throw NumberFormatException.forInputString(s); result *= radix; if (result < limit + digit) throw NumberFormatException.forInputString(s); result -= digit; } } else { throw NumberFormatException.forInputString(s); } return negative ? result : -result; } ``` 在实现中,`parseInt()` 函数会先将传入的字符串转换为整数,如果转换失败则会抛出 `NumberFormatException` 异常。它的具体实现过程如下: 1. 首先判断传入的参数是否为 `null`,如果是则抛出异常; 2. 然后判断传入的进制数是否合法,如果不在 `2` 到 `36` 的范围内则抛出异常; 3. 接着判断字符串的第一个字符,如果是 `-` 则表示是负数,否则如果是 `+` 则忽略; 4. 如果字符串只有一个符号则抛出异常; 5. 从字符串的第一个有效数字开始,按照进制数将每个字符转换为数字,然后计算出整数; 6. 如果字符串中包含非数字字符,则抛出异常; 7. 如果整数超出了 `int` 类型的范围,则抛出异常; 8. 如果字符串的长度为 `0`,则抛出异常; 9. 最后将整数返回。 需要注意的是,在实现中,`parseInt()` 函数会使用 `Character.digit()` 函数将字符转换为数字。如果字符不是数字,则返回 `-1`。如果传入的字符串包含非数字字符,则会在第一次调用 `digit()` 函数时抛出异常。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值