Java 基础 inputStream.read(bufferBytes) 读取文本错乱、异常、不全

本文讨论了解决在处理大型JSON文件时,如何避免因缓冲区累积导致数据错误的问题。方法一是通过指定每次读取的长度来更新StringBuffer;方法二是利用BufferedReader逐行读取并拼接。这两种方法有助于正确解析和处理大文件数据。

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

...
 byte[] bufferBytes = new byte[1024];
        StringBuffer stringBuilder = new StringBuffer();
        try {
            int length = 0;
            while ((length = inputStream.read(bufferBytes)) != -1) {
                stringBuilder.append(new String(bufferBytes));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
     ...

之前读小文件没啥问题,就这么用了,今天读json文件比较大的在读取的时候出现问题了

原因:因为每次 while 循环后 bufferBytes 不会清空,仍然会存在缓存上一次的数据,如果直接 bufferBytes 整个拿来 append 用,数据就错乱了,所以必须要拿每次真实读到的内容进行使用,或者套一层 BufferedReader 进行处理

  • 方法1:append 时候紧跟上指定长度
...
 byte[] bufferBytes = new byte[1024];
        StringBuffer stringBuilder = new StringBuffer();
        try {
            int length = 0;
            while ((length = inputStream.read(bufferBytes)) != -1) {
                stringBuilder.append(new String(bufferBytes, 0, length));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
     ...
  • 方法二:采用 bufferedReader.readLine 方式去读
try {
            fileInputStream = new FileInputStream(file);
            inputStreamReader = new InputStreamReader(fileInputStream);
            bufReader = new BufferedReader(inputStreamReader);
            String line = "";
            while ((line = bufReader.readLine()) != null) {
                stringBuilder.append(line);
            }
        } catch (IOException e) {
            e.printStackTrace();
           
        }
### Android串口读取数据解决方案 对于Android设备上的串行通信,确保稳定的数据传输至关重要。当遇到串口读取数据的情况时,可能由多种因素引起,包括但限于缓冲区设置当、波特率配置错误以及硬件连接稳定等问题。 #### 缓冲区管理 为了防止丢失数据,在处理输入流时应采用适当大小的缓冲区来存储接收到的信息。通常建议使用较大的缓冲区以适应同长度的消息帧。可以尝试调整`InputStream.read()`方法中的参数,或者利用更高级别的API如`BufferedInputStream`来进行优化[^1]。 ```java // 使用 BufferedInputStream 提高效率并减少部分读取的风险 try (BufferedInputStream bis = new BufferedInputStream(serialPort.getInputStream())) { byte[] buffer = new byte[1024]; // 设置合理的缓存大小 int bytesRead; while ((bytesRead = bis.read(buffer)) != -1) { handleData(Arrays.copyOfRange(buffer, 0, bytesRead)); } } catch (IOException e) { Log.e("SerialPort", "Error reading from serial port", e); } ``` #### 波特率同步 确保发送端与接收端之间具有相同的波特率非常重要。如果两端之间的波特率存在差异,则可能导致字符错乱甚至无法正常解析消息。因此,在初始化阶段务必确认双方都设定了匹配的速度值[^2]。 ```java serialPort.setParams( SerialPort.BAUDRATE_9600, SerialPort.DATABITS_8, SerialPort.STOPBITS_1, SerialPort.PARITY_NONE ); ``` #### 超时机制 有时由于网络延迟或其他原因造成某些字节未能及时到达目的地,此时可以通过设定超时时间来避免无限等待而影响程序执行流程。合理地定义SO_TIMEOUT属性可以帮助应用程序更好地应对这种情况下的异常状况。 ```java serialPort.setTimeout(500); // 半秒内未接收到任何有效载荷即触发timeout事件 ``` 通过上述措施能够有效地改善Android平台下串行接口通讯过程中可能出现的数据缺失现象。当然实际应用还需考虑更多细节方面的要求,比如线程安性和资源释放等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

louisgeek

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值