JavaIO简单摘要(二)

本文详细介绍了Java中的IO流体系,包括字符流与字节流的基本概念及其常用子类。探讨了BufferedReader、BufferedWriter等类如何提升读写效率,并解释了InputStreamReader与FileReader等转换流的作用。

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

字符流

Reader:用于读取字符流的抽象类。子类必须实现的方法只有read(char[ ],int,int)和close()

|----BufferedReader:从字符输入流中读取文本,缓冲各个字符,从而实现字符、数组和行的高效读取。可以指定缓冲区大小,或者可使用默认的大小,或者可使用默认的大小。大多数情况下,默认值就足够大了。

|----LineNumberReader:跟踪行号的缓冲字符输入流。此类定义了方法 setLineNumber(int) 和 getLineNumber() ,他们可分别用于设置和获取当前行号。

|----InputStreamReader:是字节流通向字符流的桥梁:它使用指定的charset读取字节并将其解码为字符。它使用的字符集可以由名称指定或显式给定,或者可以接受平台默认的字符集。

|----FileReader:用来读取字符文件的便捷类。此类的构造方法假定默认字符编码和默认字节缓冲区大小都是适当的。要自己指定这些值,可以先在FileInputStream上构造一个InputStreamReader。

|----CharArrayReader

|----StringReader

===================================================================================================================

Writer:写入字符流的抽象类。子类必须实现的方法仅有write(char[ ],int,int)、flush() 和close()

|----BufferedWriter:将文本写入字符输出流,缓冲各个字符,从而提供单个字符、数组和字符串的高效写入。

|----OutputStreamWriter:是字符流通向字节流的桥梁:可使用指定的charset将要写入流中的字符编码转换成字节。它使用的字符集可以由名称指定或显式给定,否则将接受平台默认的字符集。

|----FileWriter:用来写入字符文件的便捷类。此类的构造方法假定默认字符编码和默认字节缓冲区大小都是可接受的的。要自己指定这些值,可以先在FileOutputStream上构造一个OutputStreamWriter。

|----PrintWriter

|----CharArrayWriter

|----StringWriter

===================================================================================================================

字节流

InputStream:是表示字节输入流的所有类的超类

|----FileInputStream:从文件系统中的某个文件中获得输入字节。哪些文件可用取决于主机环境。FileInputStream用于读取诸如图像数据之类的原始字节流。尧都区字符流,请考虑使用FileReader

|----FilterInputStream:包含其他一些输入流,它将这些流用作其基本数据源,它可用直接传输数据或提供一些额外的功能。

|----BufferedInputStream:该类实现缓冲的输入流。

|----Stream

|----ObjectInputStream

|----PipedInputStream

===================================================================================================================

OutputStream:此抽象类是表示输出字节流的所有类的超类

|----FileOutputStream:文件输出流是用于将数据写入File或FileDescriptor的输出流

|----FilterOutputStream:此类是过滤输出流的所有类的超类

|----BufferedOutputStream:该类实现缓冲的输出流

|----PrintStream

|----DataOutputStream

|----ObjectOutputStream

|----PipedOutputStream

===================================================================================================================

缓冲区是提高效率用的,给谁提高?

BufferedWriter:是给字符输出流提高效率用的,那就意味着,缓冲区对象建立时,必须要现有流对象。明确要提高具体的流对象的效率。

package org.czty.io;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;

/**
 * Created by Chris chen on 2017/8/4.
 */
public class Test5 {
    public static void main(String[] args) throws IOException {
        FileWriter fileWriter = new FileWriter("d:/buftest.txt");
        BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);//让缓冲区和指定流关联
        for (int i = 0;i < 4;i++) {
            bufferedWriter.write(i + "chris");
            bufferedWriter.newLine();//写入一个换行符,这个换行符可以依据平台的不同写入不同的换行符
            bufferedWriter.flush();//对缓冲区进行刷新,可以让数据到目的地中
        }
        bufferedWriter.close();//关闭缓冲区,即关闭具体的流
    }
}
===================================================================================================================
BufferedReader

package org.czty.io;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;

/**
 * Created by Chris chen on 2017/8/4.
 */
public class Test6 {
    public static void main(String[] args) throws IOException {
        FileReader fileReader = new FileReader("d:/buftest.txr");
        BufferedReader bufferedReader = new BufferedReader(fileReader);
        String line = null;
        while ((line = bufferedReader.readLine()) != null) { //readLine返回时不带换行符的
            System.out.println(line);
        }
        bufferedReader.close();
    }
}
===================================================================================================================
//记住,只要一读取键盘录入,就用这句话

package org.czty.io;

import java.io.*;

/**
 * Created by Chris chen on 2017/8/4.
 */
public class Test7 {
    public static void main(String[] args) throws IOException {
        BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(System.out));//输出到控制台
        String line = null;
        while ((line = bufferedReader.readLine()) != null) {
            if ("over".equals(line))
                break;
            bufferedWriter.write(line.toUpperCase());//将输入的字符转换成大写字符输出
            bufferedWriter.newLine();
            bufferedWriter.flush();
        }
        bufferedReader.close();
        bufferedWriter.close();
    }
}
===================================================================================================================

流对象:其实很简单,就是读取和写入。但是因为功能不同,流体系中提供N多的对象。那么开始时,到底该用哪个对象更为合适呢?这就需要明确流的操作规律。

流的操作规律:

1、明确源和目的

数据源:就是需要读取,可以使用两个体系:InputStream、Reader

数据汇:就是需要写入,可以使用两个体系:OutputStream、Writer

2、操作的数据是否是纯文本数据

如果是:数据源:Reader

      数据汇:Writer

如果不是:数据源:InputStream

   数据汇:OutputStream

3、虽然确定了一个体系,但是该体系中有太多的对象,到底用哪个

明确操作的数据设备

数据源对应的设备:硬盘(File),内存(数组),键盘(System.in)

数据汇对应的设备:硬盘(File),内存(数组),控制台(System.out)

4、需要在基本操作上附加其他功能吗?比如缓冲

如果需要就进行装饰


转换流特有功能:转换流可以将字节转成字符,原因在于,将获取到的字节通过查询编码表获取到指定对应字符。


转换流的最强功能就是基于 字节流 + 编码表。没有转换,没有字符流


转换流有一个子类就是操作文件的字符流对象:

InputStreamReader

|---FileReader

OutputStreamWriter

|---FileWriter


想要操作文本文件,必须要进行编码转换,而编码转换动作转换流都完成了。所以操作文件的流对象只要继承自转换流就可以读取一个字符了。

但是子类有一个局限性,就是子类中使用的编码是固定的,是本机默认的编码表,对于简单中文版的系统默认编码表是GBK。

    FileReader fileReader = new FileReader("d:/test.txt");
    InputStreamReader inputStreamReader = new InputStreamReader(new FileInputStream("d:/test.txt"),"gbk");
以上两句代码功能一致,如果仅仅使用平台默认编码表,就使用
FileReader fileReader = new FileReader("d:/test.txt");
因为简化


如果需要制定编码表,必须用转换流

转换流 = 字节流 + 编码表

转换流的子类File = 字节流 + 默认编码表


凡是操作设备上的文本数据,涉及编码转换,必须使用转换流





内容概要:《中文大模型基准测评2025年上半年报告》由SuperCLUE团队发布,详细评估了2025年上半年中文大模型的发展状况。报告涵盖了大模型的关键进展、国内外大模型全景图及差距、专项测评基准介绍等。通过SuperCLUE基准,对45个国内外代表性大模型进行了六大任务(数学推理、科学推理、代码生成、智能体Agent、精确指令遵循、幻觉控制)的综合测评。结果显示,海外模型如o3、o4-mini(high)在推理任务上表现突出,而国内模型如Doubao-Seed-1.6-thinking-250715在智能体Agent和幻觉控制任务上表现出色。此外,报告还分析了模型性价比、效能区间分布,并对代表性模型如Doubao-Seed-1.6-thinking-250715、DeepSeek-R1-0528、GLM-4.5等进行了详细介绍。整体来看,国内大模型在特定任务上已接近国际顶尖水平,但在综合推理能力上仍有提升空间。 适用人群:对大模型技术感兴趣的科研人员、工程师、产品经理及投资者。 使用场景及目标:①了解2025年上半年中文大模型的发展现状与趋势;②评估国内外大模型在不同任务上的表现差异;③为技术选型和性能优化提供参考依据。 其他说明:报告提供了详细的测评方法、评分标准及结果分析,确保评估的科学性和公正性。此外,SuperCLUE团队还发布了多个专项测评基准,涵盖多模态、文本、推理等多个领域,为业界提供全面的测评服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值