博客
关于我
Java文件字符输入流FileReader读取txt文件乱码问题
阅读量:327 次
发布时间:2019-03-04

本文共 1067 字,大约阅读时间需要 3 分钟。

Java读取文件内容时需要注意编码格式

在实际开发中,当我们需要读取文件内容时,尤其是处理文本文件,可能会遇到编码格式相关的问题。Java中的字符流处理的最基本单元是Unicode码元(大小2字节),所以在读取文件时,我们需要注意文件的编码格式。

在代码示例中,使用了FileReader来读取文件,但未设置编码格式。FileReader默认会使用平台的默认编码格式,这可能会导致读取文件时出现问题。如果文件编码格式与默认编码不符,可能会导致无法正确读取内容,甚至出现“未找到指定路径的文件”错误。

正确的做法是在读取文件时指定编码格式。对于大多数文本文件,UTF-8是一个常用的编码格式。我们可以在创建FileReader对象时,传入指定的编码格式字符集。

文件读取示例代码如下:

public class FileInAndOut {    public static void main(String[] args) {        File file = new File("E:/大三下学期/Android/作业要求/java知识巩固/work5.txt");        if (!file.exists()) {            System.out.println("对不起,不包含指定路径的文件");            return;        }        try {            FileReader fr = new FileReader(file, "UTF-8");            char[] data = new char[51];            int length = 0;            while ((length = fr.read(data)) > 0) {                String str = new String(data, 0, length);                System.out.println(str);            }            fr.close();        } catch (Exception e) {            e.printStackTrace();        }    }}

运行示例代码,假设文件路径正确且文件存在,程序会输出文件内容。

在实际开发中,记得始终使用UTF-8编码格式,这样可以确保文件内容能够被正确读取和显示。

转载地址:http://cooq.baihongyu.com/

你可能感兴趣的文章
Oracle 9i数据库管理教程
查看>>
ORACLE Active dataguard 一个latch: row cache objects BUG
查看>>
oracle avg、count、max、min、sum、having、any、all、nvl的用法
查看>>
Oracle BEQ方式连接配置
查看>>
oracle Blob保存方式,oracle 存储过程操作blob
查看>>
Oracle BMW Racing sailing vessel帆船图
查看>>
ORACLE Bug 4431215 引发的血案—原因分析篇
查看>>
Oracle cmd乱码
查看>>
Oracle Corp甲骨文公司推出Oracle NoSQL数据库2.0版
查看>>
oracle dblink 创建使用 垮库转移数据
查看>>
oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
查看>>
Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
查看>>
oracle dg switchover,DG Switchover fails
查看>>
Oracle E-Business Suite软件 任意文件上传漏洞(CVE-2022-21587)
查看>>
Oracle EBS OPM 发放生产批
查看>>
Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
查看>>
Oracle EBS环境下查找数据源(OAF篇)
查看>>
oracle Extract 函数
查看>>
uni-app开发环境自动部署的一个误区(App running at...)
查看>>
Oracle GoldenGate Director安装和配置(无图)
查看>>