博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
parseInt的源码阅读
阅读量:5458 次
发布时间:2019-06-15

本文共 3394 字,大约阅读时间需要 11 分钟。

parseInt的源码阅读

Integer.parseInt()这个方法的功能小巧又实用,实现起来困难不大,没有很复杂。这里就来看一下Java的源码是怎么写的吧,走一边大婶写过的代码,应该会有点收获吧。

其中一条就是,为了考虑程序的健壮性,往往非核心代码占得比较少,相反各种条件判断很多。

/** * Parses the string argument as a signed integer in the radix * specified by the second argument. * * 

Examples: *

 * parseInt("0", 10) returns 0 * parseInt("473", 10) returns 473 * parseInt("+42", 10) returns 42 * parseInt("-0", 10) returns 0 * parseInt("-FF", 16) returns -255 * parseInt("1100110", 2) returns 102 * parseInt("2147483647", 10) returns 2147483647 * parseInt("-2147483648", 10) returns -2147483648 * parseInt("2147483648", 10) throws a NumberFormatException * parseInt("99", 8) throws a NumberFormatException * parseInt("Kona", 10) throws a NumberFormatException * parseInt("Kona", 27) returns 411787 * 
*/public static int parseInt(String s, int radix) throws NumberFormatException{ /* * WARNING: This method may be invoked early during VM initialization * before IntegerCache is initialized. Care must be taken to not use * the valueOf method. */ 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') { // Possible leading "+" or "-" if (firstChar == '-') { negative = true; limit = Integer.MIN_VALUE; } else if (firstChar != '+') // 如果不为++的话就报错 throw NumberFormatException.forInputString(s); // 字符串的长度为1但是又不是数字, 那肯定就出错了 if (len == 1) // Cannot have lone "+" or "-" throw NumberFormatException.forInputString(s); i++; } multmin = limit / radix; /* * 下面的过程其实很好理解, 以8进制的"534"为例 * (-5*8-3)*8-4 = -348, 根据符号位判断返回的是348 */ while (i < len) { // Accumulating negatively avoids surprises near MAX_VALUE // 除了前面的判断这里的也有点复杂, 因为要考虑到各种进位 // 这个将i位置上的字符根据基数转为实际的值, A->11 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; // 根据符号位来判断返回哪一个}
  1. 没想通的一点是,常理来说(至少我是这样的哈)是考虑用加法,然后再根据符号位判断正负,但是源码中用的是减法。这点没想通是为什么,虽然也没差,感觉怪怪的。

  2. digit = Character.digit(s.charAt(i++),radix);

    这里的函数调用里面的代码也挺多的。根据该位上的字符和基数来得到对应的数字。

转载于:https://www.cnblogs.com/tuhooo/p/6118944.html

你可能感兴趣的文章
python之scrapy模拟登陆人人网
查看>>
js实现文字无间断左右滚动和图片左右滚动
查看>>
题目11:软件工程等名词解释
查看>>
自己写平方根squareroot函数
查看>>
关于RTSP-Over-HTTP
查看>>
SQL SERVER 2005如何建立自动备份的维护计划
查看>>
深入剖析C#的多态
查看>>
SQL2008 用户'sa'登录失败(错误18456)图文解决方法
查看>>
json属性名必须加引号的讨论
查看>>
Winform--数据库链接(EF CodeFirst)
查看>>
TCP的发送缓冲区和接收缓冲区
查看>>
SQL Server的导出导入方式有
查看>>
Unity3D_(Shuriken粒子系统)制作简单的烟花爆炸效果
查看>>
3. Longest Substring Without Repeating Characters
查看>>
织梦添加搜索功能
查看>>
JDK的安装和环境变量配置
查看>>
jmeter学习记录--05--Beanshell2
查看>>
HDU1402 HDU4609 FFT快速DFT
查看>>
DataGridView添加一行数据、全选、取消全选、清空数据、删除选中行
查看>>
抽象工厂模式
查看>>