int转换为二进制

本文详细介绍了使用Java代码将整数转换为完整二进制字符串的方法,包括处理不同位数整数的填充问题。通过内建运算符实现高效转换,并提供了针对int和long类型的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 (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);       
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值