第一种方法:直接利用Integer类的静态方法toBinaryString(int i),此方法输出的二进制序列
public static String int2Binary(int num){
return Integer.toBinaryString(num);
}
第二种方法:通过位运算,将 int 类型数据转成二进制的字符串,不足 int 类型位数时在前面添“0”以凑足位数
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);
}
其中,右移运算 num>>i 是将num需要转换的向右移动 i位,再与1进行与计算, 目的是获得这个第i个二进制的数值(0或者1),
得到0或1是int类型的,+‘0’就是讲int类型的0或1转为char类型‘0’或‘1’。
(例如:int 类型是32位,加入int a=3,则a的二进制数值为:000000000000000000000000000011,当i = 0时,a向右移动0位,得到的是000000000000000000000000000011,而1的二进制数值为:000000000000000000000000000001,a&1=000000000000000000000000000001,转为int类型为1,
所以 当i=0时,(num>>i)&1=1.
当i=1时,a向右移动1位,得到的是000000000000000000000000000001,则a&1=000000000000000000000000000001,转为int类型为1,
所以 当i=1时,(num>>i)&1=1.
__________________________________________
有其他好的方法请各位读者补充一下噢,谢谢。