内存和存储设备之间传输数据的通道

流的分类

  • 按方向划分

    • 输入流(读):存储设备→内存
    • 输出流(写):内存→存储设备
  • 按单位划分、
    • 字节流:以字节为单位,可以读写所有数据
    • 字符流:以字符为单位,只能读写文本数据
  • 按功能划分
    • 节点流:具有实际传输数据的读写功能
    • 过滤流:在节点流的基础上增强功能

字节流

字节流的父类(InputStream 、 OutStream)
文件字节流
  • FileInputStream

    public int read(){}//读取单个字节
    public int read(byte[]b) {}//读取多个字节
    //读取完毕后会返回-1
  • FileOutputStream

    public void write(int n) {}//单字节写入
    public void write(byte[]b) {}//多字节写入
字节缓冲流

数据存储在缓冲区中,提高IO效率

BufferedInputStream/BufferedOutputStream

实例化字节缓冲流对象时需要一个底层流对象作为构造参数,eg:

  • BufferedInputStream in=new BufferedInputStream(new FileInputStream("路径"));
    //缓冲区的大小为8k
对象流

ObjectInputStream/ObjectOutputStream

内存 序列化> 存储设备 反序列化> 内存

调用readObject/writeObject读写对象

(1)进行序列化和反序列化的类必须实现serializable接口

  • public interface Serializable {
    }//该接口并没有抽象方法,只用来标记一个类可以被序列化

实例化对象流对象时也需要底层流对象作为构造参数

(2)除此之外,在此类内类类型的属性同样要实现serializable接口

(3)可以使用transient修饰符修饰类属性使其不被序列化,并且静态属性也不能序列化

(4)可以序列化一个集合来达到同时序列化多个对象的目的,此时反序列化的返回值也是一个集合

字符编码

字符流

字符流的父类(Reader 、Writer)
文件字符流
  • FileReader
  • FileWriter

与文件字节流实例化方法基本相同,只是传输的最小单位变为字符

文件字符流不能复制图片文件或者二进制文件

字符缓冲流
  • BufferedReader

    //readLine()方法,读取 一行文本
  • BufferedWriter

    //newLine()方法,写入一个换行符,便于多系统移植
打印流(PrintWriter)
转换流

可指定编码的字节字符转换流

  • InputStreamReader

  • OutputStreamWriter

    例如:

    new InputStreamReader(file,"UTF-8");
    //file为一个底层流对象,指定用utf-8编码读取文件
File类

代表物理盘符中的一个文件或者一个文件夹

  • createNewFile()//创建 -一个新文件
    mkdir()//创建一个新目录
    delete()//删除文件或空目录
    exists()//判断File对象所对象所代表的对象是否存在
    getAbsolutePath()//获取文件的绝对路径
    getName()//取得名字
    getParent ()//获取文件/目录所在的目录
    isDirectory()//是否是目录
    isFile()//是否是文件
    length()//获得文件的长度
    listFiles()//列出目录中的所有内容
    renameTo() //修改文件名为
  • 文件过滤器

    FileFilter接口

    File[] array=file.listFiles(new FileFilter() {
    @Override
    public boolean accept(File pathname) {
    if (pathname.getName().endsWith("txt"))
    return true;
    else
    return false;
    }//重写accept方法
    }//匿名内部类
    );//file为一个File类对象,调用listFiles方法实现过滤

Java基础篇——IO流的更多相关文章

  1. java基础之IO流(二)之字符流

    java基础之IO流(二)之字符流 字符流,顾名思义,它是以字符为数据处理单元的流对象,那么字符流和字节流之间的关系又是如何呢? 字符流可以理解为是字节流+字符编码集额一种封装与抽象,专门设计用来读写 ...

  2. java基础之IO流(一)字节流

    java基础之IO流(一)之字节流 IO流体系太大,涉及到的各种流对象,我觉得很有必要总结一下. 那什么是IO流,IO代表Input.Output,而流就是原始数据源与目标媒介的数据传输的一种抽象.典 ...

  3. Java基础之IO流整理

    Java基础之IO流 Java IO流使用装饰器设计模式,因此如果不能理清其中的关系的话很容易把各种流搞混,此文将简单的几个流进行梳理,后序遇见新的流会继续更新(本文下方还附有xmind文件链接) 抽 ...

  4. 【java基础】]IO流

    IO流 概念: 流的概念源于unix中管道(pipe)的概念,在unix中,管道是一条不间断的字节流,用来实现程序或进程间的通信,或读写外围设备,外部文件等 一个流,一定能够会有源和去向(目的地),他 ...

  5. java基础之 IO流

    javaIO流   IO流 : (input  output) 输入输出流 :输入 :将文件读到内存中 输出:将文件从内存输出到其他地方.   IO技术的作用:主要就是解决设备和设备之间的数据传输问题 ...

  6. java基础44 IO流技术(输出字节流/缓冲输出字节流)和异常处理

    一.输出字节流 输出字节流的体系: -------| OutputStream:所有输出字节流的基类(抽象类) ----------| FileOutputStream:向文件输出数据的输出字节流(把 ...

  7. java基础之io流总结一:io流概述

    IO流概念: 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.io流是实现输入和输出的基础,可以方便的实现数据的输入和输出操作. IO流的分类: 根据处理数据类型的不同分为:字符流 ...

  8. 黑马程序员——JAVA基础之IO流FileReader,FileWriter

    ------- android培训.java培训.期待与您交流! ---------- IO(Input Output)流  IO流用来处理设备之间的数据传输 Java对数据的操作是通过流的方式 J ...

  9. java基础06 IO流

    IO用于在设备间进行数据传输的操作. Java IO流类图结构:   IO流分类 字节流: InputStream FileInputStream BufferedInputStream Output ...

  10. java基础之IO流及递归理解

    一.IO流(简单理解是input/output流,数据流内存到磁盘或者从磁盘到内存等) 二.File类(就是操作文件和文件夹的) 1.FIleFile类构造方法 注意:通过构造方法创建的file对象是 ...

随机推荐

  1. Arctic 基于 Hive 的流批一体实践

    背景 随着大数据业务的发展,基于 Hive 的数仓体系逐渐难以满足日益增长的业务需求,一方面已有很大体量的用户,但是在实时性,功能性上严重缺失:另一方面 Hudi,Iceberg 这类系统在事务性,快 ...

  2. Maven 聚合工程的创建

    简单场景举例 聚合工程创建示例 说明: 创建 Maven Project:表示创建 maven 项目,new Project 方式创建 创建 Maven Module:表示创建 maven 项目,ne ...

  3. day10-Tomcat02

    Tomcat02 4.IDEA开发JavaWeb工程 4.1开发javaweb工程&配置Tomcat&启动项目 需求:使用idea开发javaweb工程fishWeb,并将网页部署到f ...

  4. Oracle部署,关于日志文件系统选择(硬盘格式化、挂载)

    之前部署过好多Oracle服务,采用的日志文件系统一直是ext3.但是我观察到很多人在格式化/挂载数据盘时,采用的日志文件系统类型有ext3.ext4.xfs等,这不禁让我发出疑问,哪个类型的数据处理 ...

  5. 2021年WebStorm安装破解教程

    一.WebStorm工具介绍 WebStorm是一款JavaScript 开发工具,为JavaScript和编译到JavaScript语言.Node.js.HTML和CSS提供了智能编码帮助.享受代码 ...

  6. 如何重启kafka

    修改配置文件 ps -ef |grep kafka kill (kafka进程号) 启动kafka [root@lecode-dev-001 bin]# ./kafka-server-start.sh ...

  7. 2022!影响百万用户金融信用评分,Equifax被告上法庭,罪魁祸首——『数据漂移』!⛵

    作者:韩信子@ShowMeAI 数据分析实战系列:https://www.showmeai.tech/tutorials/40 机器学习实战系列:https://www.showmeai.tech/t ...

  8. 已经有 MESI 协议,为什么还需要 volatile 关键字?

    本文已收录到  GitHub · AndroidFamily,有 Android 进阶知识体系,欢迎 Star.技术和职场问题,请关注公众号 [彭旭锐] 进 Android 面试交流群. 前言 大家好 ...

  9. python面试题常用语句

    一.比较与交换1.比较并输出大的 print(a if a>b else b) 2.交换两个元素 a,b = b,alist1[i],list[j]=list1[j],list[i] 二.排序 ...

  10. Linux 交叉编译使用代码覆盖GCOV及LCOV

    1. GCOV GCOV是GCC自带的代码覆盖工具,GCOV. 在 GCC 编译的时加入特殊的编译选项,生成可执行文件,和 *.gcno: 运行(测试)生成的可执行文件,生成了 *.gcda 数据文件 ...