关于读写数据出现部分中文乱码的问题记述

本文探讨了在使用Java进行网络编程时遇到的中文乱码问题。通过分析测试,发现字节数不足导致的乱码现象。提出了两种解决方案:一是根据实际可用字节调整缓冲区大小;二是改用字符流避免字节操作引发的乱码。这两种方法都能有效防止中文乱码的出现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一丶问题描述

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

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);
       }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值