java byte[]转String再转回byte[]不一致问题
问题原因 :
new String(byte[])和getBytes()默认使用的编码都是通过这条语句获取的编码
解决原理:
由于UTF-8是多字节编码,需要用多个字节来表示一个字符的编码,所以也就出现了在转换之后byte[]数组长度、内容不一致的情况。
而ISO-8859-1编码是单字节编码,所以使用该编码就不会出现上面的问题
测试代码:
import java.nio.charset.Charset;import java.util.Arrays;public class test { public static void main(String[] args) { byte[] bytes = new byte[] { 41, -31, -91, 41, -71, -11 }; byte[] myBytes = new String(bytes).getBytes(); System.out.println(Arrays.toString(bytes)); System.out.println(Arrays.toString(myBytes)); // 问题原因 :new String(byte[])和getBytes()默认使用的编码都是通过这条语句获取的编码 // 获取默认编码 System.out.println(Charset.defaultCharset().name()); // 解决原理 // 由于UTF-8是多字节编码,需要用多个字节来表示一个字符的编码,所以也就出现了在转换之后byte[]数组长度、内容不一致的情况。 // 而ISO-8859-1编码是单字节编码,所以使用该编码就不会出现上面的问题 byte[] bytes3 = new String(bytes, Charset.forName("ISO-8859-1")).getBytes(Charset.forName("ISO-8859-1")); System.out.println(Arrays.toString(bytes3)); }}参考文章:https://blog.csdn.net/wusj3/article/details/80606728
原文转载:http://www.shaoqun.com/a/497403.html
名人堂是什么:https://www.ikjzd.com/w/1082
万国邮政联盟:https://www.ikjzd.com/w/861
rfq:https://www.ikjzd.com/w/251
javabyte[]转String再转回byte[]不一致问题问题原因:newString(byte[])和getBytes()默认使用的编码都是通过这条语句获取的编码解决原理: 由于UTF-8是多字节编码,需要用多个字节来表示一个字符的编码,所以也就出现了在转换之后byte[]数组长度、内容不一致的情况。 而ISO-8859-1编码是单字节编码,所以使用该编码就不会出现上面的问题测试代码:i
贝恩:贝恩
anker:anker
广州有什么土特产?最好吃的美食有哪些?:广州有什么土特产?最好吃的美食有哪些?
去泰国之前要准备哪些东西?要带什么?:去泰国之前要准备哪些东西?要带什么?
珠澳海湾游时间?珠海珠澳海湾游需要多长时间?:珠澳海湾游时间?珠海珠澳海湾游需要多长时间?
No comments:
Post a Comment