今天来分析一波Integer.toString(int i, int radix)
是怎么实现二进制到三十六进制的字符串输出的
// i是我们要转化的数,radix是几进制
public static String toString(int i, int radix) {
// 两个常量分别是2和36,用来限制进制转化的范围,至于为何最高是36进制
// 是因为数字加字母(不区分大小写)共36个数码
// 当radix输入不在范围内时按默认的十进制输出
if (radix < Character.MIN_RADIX || radix > Character.MAX_RADIX)
radix = 10;
// 要是十进制直接用的Integer类的toString()方法,没必要转化
/* Use the faster version */
if (radix == 10) {
return toString(i);
}
// 新建长度为33的char型数组,为何为长度为33呢,因为在所有进制中,
// 对于同一数的不同进制表示,二进制表示的长度最长,而Integer的范围
// 在-2^31~2^31-1之间,需要32位来表示,再加上负数的符号就是33位了.
// 这样也正解释了charPos为何取32,即数组的最大的下标。
// i是否是正数,要是正数就变成负数,后面我们研究下什么变成负数来处理
char buf[] = new char[33];
boolean negative = (i < 0);
int charPos = 32;
if (!negative) {
i = -i;
}
// 这里笔者实在想不到采用负数与正数有什么区别
while (i <= -radix) {
// digits是一维数组,存放着所有数字和字母,按0~9,a~z的顺序排列
buf[charPos--] = digits[-(i % radix)];
i = i / radix;
}
buf[charPos] = digits[-i];
// 把符号加上
if (negative) {
buf[--charPos] = '-';
}
// 然后使用String类的构造方法,从charPos开始,到指定长度结束
return new String(buf, charPos, (33 - charPos));
}