Integer源码学习(JAVA)

来源:互联网 发布:量子处理器 知乎 编辑:程序博客网 时间:2024/05/17 06:40

Integer类中的两个friendly方法 (不可访问)

1.int stringSize(int x)//求一个整数的位数。

final static int [] sizeTable = { 9, 99, 999, 9999, 99999, 999999, 9999999,99999999, 999999999, Integer.MAX_VALUE // Requires positive x 要求一个正数xstatic int stringSize(int x) {    for (int i=0; ; i++){            if (x <= sizeTable[i])                return i+1;    }

2.void getChars(int i, int index, char[] buf)//将一个整数i用一个字符数组buf[]来表示,index是整数的位数,包括符号位在内。

static void getChars(int i, int index, char[] buf) {        int q, r;        int charPos = index;        char sign = 0;        if (i < 0) {            sign = '-';            i = -i;        }        // Generate two digits per iteration 每个迭代生成两位数        // 当 i > = 65536 的时候        while (i >= 65536) {            q = i / 100;        // really: r = i - (q * 100);        // 余数r            r = i - ((q << 6) + (q << 5) + (q << 2));            i = q;            buf [--charPos] = DigitOnes[r];            buf [--charPos] = DigitTens[r];        }        // Fall thru to fast mode for smaller numbers 对于较小数字的快速模式        // assert(i <= 65536, i);        // 当i < = 65536 的时候        for (;;) {            q = (i * 52429) >>> (16+3);//相当于除十            r = i - ((q << 3) + (q << 1));  // r = i-(q*10) ...            buf [--charPos] = digits [r];            i = q;            if (i == 0) break;        }        if (sign != 0) {            buf [--charPos] = sign;        }    }

Integer类中可以访问的方法

1.构造函数

public Integer(int value) {        this.value = value;    }public Integer(String s) throws NumberFormatException {        this.value = parseInt(s, 10);    }`

2.String toString(int i, int radix)//将一个整型十进制数字i转换为radix(MIN_RADIX = 2, MAX_RADIX = 36)进制的String类型的值,如果进制超出规定范围,则默认为十进制

0 0
原创粉丝点击