java中的Integer的toBinaryString()方法實(shí)例
在一次面試的過(guò)程中,遇到過(guò)這樣的題目,題目的大概意思是:讓寫(xiě)出Integer類中的toBinaryString()方法
也就是說(shuō),把Integer轉(zhuǎn)換為Binary的過(guò)程寫(xiě)出來(lái)
但是我蒙的,在查了JDK的源碼,發(fā)現(xiàn)了這個(gè)很好用的方法,在此給大伙看看
下面是我做的一個(gè)測(cè)試:
/**
*
*/
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();
}
/**
* 這里是做&操作的測(cè)試,也就是說(shuō),在1&*(其中*代表其他數(shù)字,如:0,1,2,3,4...)操作的時(shí)候
* 他們是進(jìn)行二進(jìn)制之間的&(與)運(yùn)算操作。只有當(dāng)*為奇數(shù)(1,3,5,7...)的時(shí)候,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,所以當(dāng)i為奇數(shù)的時(shí)候,這里"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'
};
}
在代碼中,其實(shí)我們可以簡(jiǎn)化一下digits數(shù)組,因?yàn)槲覀冎粫?huì)用到數(shù)組:digits[0],digits[1]
所以:
final static char[] digits = {
'0' , '1'
};
方法里面用到了移位操作和&操作,這兩個(gè)操作是關(guān)鍵。
相關(guān)文章
SpringBoot使用token簡(jiǎn)單鑒權(quán)的具體實(shí)現(xiàn)方法
這篇文章主要介紹了SpringBoot使用token簡(jiǎn)單鑒權(quán)的具體實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11Java如何重寫(xiě)object類的equals方法詳解
這篇文章主要給大家介紹了關(guān)于Java如何重寫(xiě)object類的equals方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12關(guān)于Linux服務(wù)器配置java環(huán)境遇到的問(wèn)題小結(jié)
這篇文章主要介紹了關(guān)于Linux服務(wù)器配置java環(huán)境遇到的問(wèn)題小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Springboot2 集成 druid 加密數(shù)據(jù)庫(kù)密碼的配置方法
這篇文章給大家介紹Springboot2 集成 druid 加密數(shù)據(jù)庫(kù)密碼的配置方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2021-07-07Java創(chuàng)建多線程異步執(zhí)行實(shí)現(xiàn)代碼解析
這篇文章主要介紹了Java創(chuàng)建多線程異步執(zhí)行實(shí)現(xiàn)代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07Spring @ExceptionHandler注解統(tǒng)一異常處理和獲取方法名
這篇文章主要介紹了Spring注解之@ExceptionHandler 統(tǒng)一異常處理和獲取方法名,在實(shí)際項(xiàng)目中,合理使用@ExceptionHandler能夠提高代碼的可維護(hù)性和用戶體驗(yàn),通過(guò)本文的解析和實(shí)踐,讀者可以更好地理解和掌握@ExceptionHandler的用法和原理2023-09-09JFinal實(shí)現(xiàn)偽靜態(tài)的方法
JFinal 是基于 Java 語(yǔ)言的極速 WEB + ORM 框架,其核心設(shè)計(jì)目標(biāo)是開(kāi)發(fā)迅速、代碼量少、學(xué)習(xí)簡(jiǎn)單、功能強(qiáng)大、輕量級(jí)、易擴(kuò)展、Restful。這篇文章主要介紹了JFinal實(shí)現(xiàn)偽靜態(tài),需要的朋友可以參考下2018-04-04