java utf8 gb2312_java utf8 转 gb2312 错误?

题主应该是对编解码有误解。

getBytes(String charsetName) 是指用 chasetName 代表的编码格式对字符串进行编码得到字节数组。

String(byte bytes[], String charsetName) 构造方法是指用 chasetName 代表的编码格式 对直接数组进行解码得到字符串。

也就是说,得到以某种格式编码的字符数组只用 getBytes(String charsetName) 这一步就可以了。该字节数组需要用编码时同样的编码格式进行解码。否则会乱码。如果,这时候用已经乱码的字符串再转换编码,是不一定能得到之前正确的编码字节数组的。

示例:

String str = "上海上海"; // 我这设置 file.encoding 为 UTF-8

byte[] utf8Bytes = str.getBytes("utf-8");

byte[] defaultBytes = str.getBytes();

Assert.assertArrayEquals(utf8Bytes, defaultBytes);

byte[] gbkBytes = str.getBytes("GBK");

// Assert.assertArrayEquals(utf8Bytes, gbkBytes);// 这儿不过!! array lengths differed, expected.length=12 actual.length=8。

String errorStr = new String(gbkBytes, "utf-8");// 此时是乱码的

Assert.assertNotEquals(str, errorStr); // 肯定不一样

byte[] errorUtf8Bytes = errorStr.getBytes("utf-8"); // 乱码后重新编码

// Assert.assertArrayEquals(gbkBytes, errorUtf8Bytes); // 不过! 已经和之前的字节数组不一样了。array lengths differed, expected.length=8 actual.length=16

// Assert.assertArrayEquals(utf8Bytes, errorUtf8Bytes); // 不过! 更不会和 utf8Bytes 相同。array lengths differed, expected.length=12 actual.length=16

其中:errorStr 为 "�Ϻ��Ϻ�"

另外字节数组为:

27c9913ce87bcc5992da893badf32b99.png

25d1e6f9b12b34fbd2f04e2a7057c8f2.png

d2dd3d34fceeff75a731b9572f98c650.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值