java中的Integer的toBinaryString()辦法實例。本站提示廣大學習愛好者:(java中的Integer的toBinaryString()辦法實例)文章只能為提供參考,不一定能成為您想要的結果。以下是java中的Integer的toBinaryString()辦法實例正文
在一次面試的進程中,碰到過如許的標題,標題的年夜概意思是:讓寫出Integer類中的toBinaryString()辦法
也就是說,把Integer轉換為Binary的進程寫出來
然則我蒙的,在查了JDK的源碼,發明了這個很好用的辦法,在此給年夜伙看看
上面是我做的一個測試:
/**
*
*/
package com.b510.test;
/**
* @author Hongten
* @date 2013-12-15
*/
public class TestF {
public static void main(String[] args) {
//output:1000
System.out.println(toBinaryString(8));
//printInfo();
}
/**
* 這裡是做&操作的測試,也就是說,在1&*(個中*代表其他數字,如:0,1,2,3,4...)操作的時刻
* 他們是停止二進制之間的&(與)運算操作。只要當*為奇數(1,3,5,7...)的時刻,1*&操作才可以前往:1
* 其他情形前往:0
*/
private static void printInfo(){
for(int i =0; i< 10; i++){
System.out.println("i= " + i + " "+(i & 1));
}
/*
output:
i= 0 0
i= 1 1
i= 2 0
i= 3 1
i= 4 0
i= 5 1
i= 6 0
i= 7 1
i= 8 0
i= 9 1
*/
}
public static String toBinaryString(int i) {
return toUnsignedString(i, 1);
}
/**
* Convert the integer to an unsigned number.
*/
private static String toUnsignedString(int i, int shift) {
char[] buf = new char[32];
int charPos = 32;
int radix = 1 << shift;
int mask = radix - 1;
do {
//這裡的mask一向為:1,所以當i為奇數的時刻,這裡"i & mask"操作才為:1
//不然前往:0
//System.out.println(i & mask);
buf[--charPos] = digits[i & mask];
i >>>= shift;//右移賦值,右邊空出的位以0填充
//System.out.println(buf);
//System.out.println(charPos);
//System.out.println(i);
} while (i != 0);
return new String(buf, charPos, (32 - charPos));
}
final static char[] digits = {
'0' , '1' , '2' , '3' , '4' , '5' ,
'6' , '7' , '8' , '9' , 'a' , 'b' ,
'c' , 'd' , 'e' , 'f' , 'g' , 'h' ,
'i' , 'j' , 'k' , 'l' , 'm' , 'n' ,
'o' , 'p' , 'q' , 'r' , 's' , 't' ,
'u' , 'v' , 'w' , 'x' , 'y' , 'z'
};
}
在代碼中,其實我們可以簡化一下digits數組,由於我們只會用到數組:digits[0],digits[1]
所以:
final static char[] digits = {
'0' , '1'
};
辦法外面用到了移位操作和&操作,這兩個操作是症結。