二进制十六进制工具类

来源:互联网 发布:风险矩阵评价法 编辑:程序博客网 时间:2024/06/06 00:58
public class NumberUtil {
   
    private final static char[] HEX = "0123456789abcdef".toCharArray();
   
    /**
     * 将 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);       
    }
   
    /**
     * 将 int 类型数据转成十六进制的字符串,不足 int 类型位数时在前面添“0”以凑足位数
     * @param num
     * @return
     */
    public static String toFullHexString(int num) {
        char[] chs = new char[Integer.SIZE / 4];
        for(int i = 0; i < chs.length; i++) {
            chs[chs.length - 1 - i] = HEX[(num >> (i * 4)) & 0xf];
        }
        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);       
    }
   
    /**
     * 将 long 类型数据转成十六进制的字符串,不足 long 类型位数时在前面添“0”以凑足位数
     * @param num
     * @return
     */
    public static String toFullHexString(long num) {
        char[] chs = new char[Long.SIZE / 4];
        for(int i = 0; i < chs.length; i++) {
            chs[chs.length - 1 - i] = HEX[(int)((num >> (i * 4)) & 0xf)];
        }
        return new String(chs);
    }
}
原创粉丝点击