本文介紹了將字符串內容解析為二進制,然后在Java中轉換為字符串的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我需要將字符串內容解析為二進制序列,并將它們轉換為其UTF-8等效字符串。
例如,UTF-8B、A和R的二進制等效項如下:
B=01000010
A=01000001
R=01010010
現在,我需要將一個字符串“010000100100000101010010”轉換為字符串“bar”
即對于上述情況,24個字符的輸入字符串被分成三個相等的部分(每個部分8個字符),并轉換為與字符串值等效的UTF-8。
示例代碼:
public static void main(String args[]) {
String B = "01000010";
String A = "01000001";
String R = "01010010";
String BAR = "010000100100000101010010";
String utfEquiv = toUTF8(BAR);//expecting to get "BAR"
System.out.println(utfEquiv);
}
private static String toUTF8(String str) {
// TODO
return "";
}
方法toUTF8(字符串str){}
應該實現什么
推薦答案
您應該將其分為兩個問題:
通過解析二進制值將字符串轉換為字節數組
使用UTF-8將字節數組轉換回字符串
后者非常簡單,使用new String(bytes, StandardCharsets.UTF_8)
。
對于第一部分,棘手的部分是Byte.parseByte
不會自動處理前導1…因此,我可能會將每個8位字符串解析為short
,然后轉換為byte
:
public static byte[] binaryToBytes(String input) {
// TODO: Argument validation (nullity, length)
byte[] ret = new byte[input.length() / 8];
for (int i = 0; i < ret.length; i++) {
String chunk = input.substring(i * 8, i * 8 + 8);
ret[i] = (byte) Short.parseShort(chunk, 2);
}
return ret;
}
這篇關于將字符串內容解析為二進制,然后在Java中轉換為字符串的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,