本文介紹了將字符串內(nèi)容解析為二進(jìn)制,然后在Java中轉(zhuǎn)換為字符串的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!
問(wèn)題描述
我需要將字符串內(nèi)容解析為二進(jìn)制序列,并將它們轉(zhuǎn)換為其UTF-8等效字符串。
例如,UTF-8B、A和R的二進(jìn)制等效項(xiàng)如下:
B=01000010
A=01000001
R=01010010
現(xiàn)在,我需要將一個(gè)字符串“010000100100000101010010”轉(zhuǎn)換為字符串“bar”
即對(duì)于上述情況,24個(gè)字符的輸入字符串被分成三個(gè)相等的部分(每個(gè)部分8個(gè)字符),并轉(zhuǎn)換為與字符串值等效的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){}
應(yīng)該實(shí)現(xiàn)什么
推薦答案
您應(yīng)該將其分為兩個(gè)問(wèn)題:
通過(guò)解析二進(jìn)制值將字符串轉(zhuǎn)換為字節(jié)數(shù)組
使用UTF-8將字節(jié)數(shù)組轉(zhuǎn)換回字符串
后者非常簡(jiǎn)單,使用new String(bytes, StandardCharsets.UTF_8)
。
對(duì)于第一部分,棘手的部分是Byte.parseByte
不會(huì)自動(dòng)處理前導(dǎo)1…因此,我可能會(huì)將每個(gè)8位字符串解析為short
,然后轉(zhuǎn)換為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;
}
這篇關(guān)于將字符串內(nèi)容解析為二進(jìn)制,然后在Java中轉(zhuǎn)換為字符串的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,