码迷,mamicode.com
首页 > 其他好文 > 详细

Integer源码 转2进制转16进制

时间:2014-09-03 13:11:06      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:blog   os   java   ar   2014   sp   log   amp   c   


其中有一个私有方法,toUnsignedString(int i, int shift) 是为 
 public static String toHexString(int i) {
        return toUnsignedString(i, 4);
 }
public static String toBinaryString(int i) {
        return toUnsignedString(i, 1);
 }
着两个方法服务的。

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'
	    };
	 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 {
	            buf[--charPos] = digits[i & mask];
	            i >>>= shift;
	        } while (i != 0);


	        return new String(buf, charPos, (32 - charPos));
	    }
以559转为16进制为例:

559 二进制位 10 0010 1111;

toUnsignedString(i, 4);
1.取4位计算对应的16进制字符;
2.然后右移4位,前面补0;
重复1 ,2;
----------
mask = 15,对应 1111;

          10 0010 1111 & mask = 1111 -> 15 -> digits[15] -> f;
右移4位后 00 0010 0010 & mask = 0010 -> 2 -> digits[2] -> 2;
右移4位后 00 0000 0010 & mask = 0010 -> 2 -> digits[2] -> 2; 

----> 22f

同样如果转为8进制则为:toUnsignedString(i, 3);

感觉自己写的算法都弱爆了

Integer源码 转2进制转16进制

标签:blog   os   java   ar   2014   sp   log   amp   c   

原文地址:http://blog.csdn.net/wufengui1315/article/details/39025091

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!