将二进制1s和0的整数(或字符串)阵列转换为Java中的Alpha等效物



我有一个整数1和0(可能需要转换为byte类型?)。我已经使用[在线ASCII到二进制发电机] [1]获取此6位数字字母序列的等效二进制文件:

abcdef在二进制中应等于 011000010110001001100011011001000110010101100110

我的数组被设置为int[] curCheckArr = new int[48];,我的字符串基本上只是使用StringBuilder来构建与字符串相同的INT,并调用toString()-因此我可以访问代码作为字符串或数组。

我尝试了一些不同的方法,所有这些方法都崩溃了浏览器,包括:

StringBuilder curCheckAlphaSB = new StringBuilder(); // Some place to store the chars
Arrays.stream( // Create a Stream
    curCheckString.split("(?<=\G.{8})") // Splits the input string into 8-char-sections (Since a char has 8 bits = 1 byte)
).forEach(s -> // Go through each 8-char-section...
curCheckAlphaSB.append((char) Integer.parseInt(s, 2)) // ...and turn it into an int and then to a char
);
String curAlpha = curCheckAlphaSB.toString();

String curAlpha = "";
for (int b = 0; b < curCheckString.length()/8; b++) {
    int a = Integer.parseInt(curAlpha.substring(8*b,(b+1)*8),2);
    curAlpha += (char)(a);
}

如何最有效地将这48 1s和0s转换为六位数alpha字符序列?

假设每个字符恰好用一个byte表示您可以用Integer.parseInt()迭代输入(因为输入中的byte值可能是未签名的):

>
String input = "011000010110001001100011011001000110010101100110";
StringBuilder sb = new StringBuilder();
for (int i = 0; i < input.length(); i += 8) {
    int c = Integer.parseInt(input.substring(i, i + 8), 2);
    sb.append((char) c);
}
System.out.println(sb); // abcdef

使用正则表达式可能是其中最慢的部分。使用预编译的正则义务会有所帮助,但是子字符串速度更快。没有创建任何字符串,除了结果会更快。例如使用StringBuilder代替+=作为字符串。

最新更新