(char)(((num>> i)&1)+’0′); 这里实现把num需要转换的向右移动 i位,目的是获得这个第i个二进制的数值(0或者1),
因为1的二进制的特殊性!! 可以获得第i位的二进制数值 。这样就能获得字符‘0’或‘1’ ,然后转换成string就ok
Java代码如下:
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);
}
}