Преобразование шестнадцатеричной строки (шестнадцатеричной) в двоичную строку - PullRequest
21 голосов
/ 12 февраля 2012

Я нашел следующий способ преобразования шестнадцатеричного значения в двоичное:

String binAddr = Integer.toBinaryString(Integer.parseInt(hexAddr, 16)); 

В то время как этот подход работает для небольших шестнадцатеричных чисел, шестнадцатеричное число, такое как следующее

A14AA1DBDB818F9759

Бросает NumberFormatException.

Поэтому я написал следующий метод, который, кажется, работает:

private String hexToBin(String hex){
    String bin = "";
    String binFragment = "";
    int iHex;
    hex = hex.trim();
    hex = hex.replaceFirst("0x", "");

    for(int i = 0; i < hex.length(); i++){
        iHex = Integer.parseInt(""+hex.charAt(i),16);
        binFragment = Integer.toBinaryString(iHex);

        while(binFragment.length() < 4){
            binFragment = "0" + binFragment;
        }
        bin += binFragment;
    }
    return bin;
}

Приведенный выше метод в основном берет каждый символ в шестнадцатеричной строке и преобразует его в двоичный эквивалент, дополняет его нулями, если необходимо, затем присоединяет его к возвращаемому значению. Это правильный способ выполнить преобразование? Или я пропускаю что-то, что может привести к провалу моего подхода?

Заранее благодарим за любую помощь.

Ответы [ 6 ]

35 голосов
/ 12 февраля 2012

BigInteger.toString(radix) будет делать то, что вы хотите. Просто пройдите в основание 2.

static String hexToBin(String s) {
  return new BigInteger(s, 16).toString(2);
}
4 голосов
/ 15 апреля 2015
Integer.parseInt(hex,16);    
System.out.print(Integer.toBinaryString(hex));

Разобрать шестнадцатеричное (String) в целое число с основанием 16, затем преобразовать его в двоичную строку, используя метод toBinaryString (int)

пример

int num = (Integer.parseInt("A2B", 16));
System.out.print(Integer.toBinaryString(num));

Будет печатать

101000101011

Макс. Hex vakue. Обрабатывается с помощью int как FFFFFFF

, т. Е. Если FFFFFFF0 пройден, t выдаст ошибку

2 голосов
/ 26 ноября 2015

Со всеми нулями:

static String hexToBin(String s) {
    String preBin = new BigInteger(s, 16).toString(2);
    Integer length = preBin.length();
    if (length < 8) {
        for (int i = 0; i < 8 - length; i++) {
            preBin = "0" + preBin;
        }
    }
    return preBin;
}
1 голос
/ 03 февраля 2016
public static byte[] hexToBin(String str)
    {
        int len = str.length();
        byte[] out = new byte[len / 2];
        int endIndx;

        for (int i = 0; i < len; i = i + 2)
        {
            endIndx = i + 2;
            if (endIndx > len)
                endIndx = len - 1;
            out[i / 2] = (byte) Integer.parseInt(str.substring(i, endIndx), 16);
        }
        return out;
    }
0 голосов
/ 17 января 2019
public static byte[] hexToBytes(String string) {
 int length = string.length();
 byte[] data = new byte[length / 2];
 for (int i = 0; i < length; i += 2) {
  data[i / 2] = (byte)((Character.digit(string.charAt(i), 16) << 4) + Character.digit(string.charAt(i + 1), 16));
 }
 return data;
}
0 голосов
/ 01 ноября 2017
import java.util.*;
public class HexadeciamlToBinary
{
   public static void main()
   {
       Scanner sc=new Scanner(System.in);
       System.out.println("enter the hexadecimal number");
       String s=sc.nextLine();
       String p="";
       long n=0;
       int c=0;
       for(int i=s.length()-1;i>=0;i--)
       {
          if(s.charAt(i)=='A')
          {
             n=n+(long)(Math.pow(16,c)*10);
             c++;
          }
         else if(s.charAt(i)=='B')
         {
            n=n+(long)(Math.pow(16,c)*11);
            c++;
         }
        else if(s.charAt(i)=='C')
        {
            n=n+(long)(Math.pow(16,c)*12);
            c++;
        }
        else if(s.charAt(i)=='D')
        {
           n=n+(long)(Math.pow(16,c)*13);
           c++;
        }
        else if(s.charAt(i)=='E')
        {
            n=n+(long)(Math.pow(16,c)*14);
            c++;
        }
        else if(s.charAt(i)=='F')
        {
            n=n+(long)(Math.pow(16,c)*15);
            c++;
        }
        else
        {
            n=n+(long)Math.pow(16,c)*(long)s.charAt(i);
            c++;
        }
    }
    String s1="",k="";
    if(n>1)
    {
    while(n>0)
    {
        if(n%2==0)
        {
            k=k+"0";
            n=n/2;
        }
        else
        {
            k=k+"1";
            n=n/2;
        }
    }
    for(int i=0;i<k.length();i++)
    {
        s1=k.charAt(i)+s1;
    }
    System.out.println("The respective binary number is : "+s1);
    }
    else
    {
        System.out.println("The respective binary number is : "+n);
    }
  }
}
...