不灭的焱

革命尚未成功,同志仍须努力下载JDK17

作者:Albert.Wen  添加时间:2022-08-24 19:08:29  修改时间:2024-04-14 14:49:12  分类:Java基础  编辑

一丶问题描述

使用输出流和输入流进行读写数据时,会出现部分中文乱码的问题,如下代码是按字节进行数据写入,当改变字节的大小时,出现中文乱码的位置还不一样 !

InputStream is = httpConn.getInputStream();
byte[] b = new byte[1024];
     int len;
     while ((len = is.read(b)) != -1) {
           String s = new String(b, 0, len, StandardCharsets.UTF_8);
           sb.append(s);
 }

二丶测试结论

因改变字节大小出现乱码位置不同,可得出结果就是当字节不够时又刚好在读写中文时,因字节长度不够装一个中文时,就会出现乱码的情况 。

三丶解决方案

1丶将写入字节设置为当前最大, 代码如下 :

InputStream is = httpConn.getInputStream();
byte[] b = new byte[is.available()];
     int len;
     while ((len = is.read(b)) != -1) {
           String s = new String(b, 0, len, StandardCharsets.UTF_8);
           sb.append(s);
 }

2丶不使用字节读写方式, 使用字符的读写方式, 将字节流转换为字符流, 代码如下 :

InputStream is = httpConn.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
char[] bufChar = new char[20];
int nBufLen = isr.read(bufChar);
while(nBufLen != -1){
	 sb.append(new String(bufChar, 0, nBufLen));
	 nBufLen = isr.read(bufChar);
}

 

 

摘自:

  1. 关于读写数据出现部分中文乱码的问题记述
  2. 字节流读取文本可能产生乱码的原因