Java源码分析(1)

今天来分析一波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));
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值