有什么方法可以将Java转换String为byte[](而不是盒装Byte[])?
String为byte[](
Byte[]
在尝试这个:
System.out.println(response.split("\r\n\r\n")[1]); System.out.println("******"); System.out.println(response.split("\r\n\r\n")[1].getBytes().toString());
我得到单独的输出。由于是gzip字符串,因此无法显示第一个输出。
<A Gzip String> ****** [B@38ee9f13
第二个是地址。我做错了什么吗?我需要将结果byte[]送入gzip解压缩器,如下所示。
String decompressGZIP(byte[] gzip) throws IOException { java.util.zip.Inflater inf = new java.util.zip.Inflater(); java.io.ByteArrayInputStream bytein = new java.io.ByteArrayInputStream(gzip); java.util.zip.GZIPInputStream gzin = new java.util.zip.GZIPInputStream(bytein); java.io.ByteArrayOutputStream byteout = new java.io.ByteArrayOutputStream(); int res = 0; byte buf[] = new byte[1024]; while (res >= 0) { res = gzin.read(buf, 0, buf.length); if (res > 0) { byteout.write(buf, 0, res); } } byte uncompressed[] = byteout.toByteArray(); return (uncompressed.toString()); }
你的方法decompressGZIP()需要的对象是byte[]。
decompressGZIP()
byte[]
因此,对你提出的问题的基本技术回答是:
byte[] b = string.getBytes(); byte[] b = string.getBytes(Charset.forName("UTF-8")); byte[] b = string.getBytes(StandardCharsets.UTF_8); // Java 7+ only
但是,你似乎在努力解决的问题是,它显示得不是很好。调用toString()只会为你提供默认Object.toString()名称,即类名+内存地址。在你的结果中[B@38ee9f13,[B均值byte[]和38ee9f13是内存地址,以分隔@。
Object.toString()
+
B@38ee9f13
B
38ee9f13
@
为了显示目的,你可以使用:
Arrays.toString(bytes);
但这只会显示为逗号分隔的整数序列,可能不是你想要的整数。
为了得到一个可读的String从背面byte[],使用方法:
String
String string = new String(byte[] bytes, Charset charset);
支持该Charset版本的原因是StringJava中的所有对象在内部都存储为UTF-16。转换为a时byte[],对于给定的字形,你将获得不同的字节细分String,具体取决于所选的字符集。
StringJava