研究了下!!真的很牛!!lz如果想真的了解位制转换机制,最好研究下!!
(char)(((num>> i)&1)+'0');
这里实现把num需要转换的向右移动 i位 目的是获得这个第i个二进制的数值(0或者1)
因为1的二进制的特殊性!!
可以获得第i位的二进制数值
这样 就能获得字符‘0’或‘1’
然后转换成string就ok
public class Test {
public static void main(String[] args) {
int a = 355;
System.out.println(toFullBinaryString(a)); // 输出完整的二进制序列
System.out.println(Integer.toBinaryString(a)); // 输出二进制序列
}
/**
* 将 int 类型数据转成二进制的字符串,不足 int 类型位数时在前面添“0”以凑足位数
* @param num
* @return
*/
public static String toFullBinaryString(int num) {
char[] chs = new char[Integer.SIZE];
for(int i = 0; i < Integer.SIZE; i++) {
chs[Integer.SIZE - 1 - i] = (char)(((num >> i) & 1) + '0');
}
return new String(chs);
}
/**
* 将 long 类型数据转成二进制的字符串,不足 long 类型位数时在前面添“0”以凑足位数
* @param num
* @return
*/
public static String toFullBinaryString(long num) {
char[] chs = new char[Long.SIZE];
for(int i = 0; i < Long.SIZE; i++) {
chs[Long.SIZE - 1 - i] = (char)(((num >> i) & 1) + '0');
}
return new String(chs);
}
}