IO流用来处理设备之间的数据传输
Java对数据的操作是通过流的方式
Java用于操作流的对象都在IO包中

流按照操作数据分为两种:字节流和字符流
流按流向分为:输入流和输出流

输入流和输出流是相对于内存设备而言

因为内存速度快,程序在内存中运行,数据从外设(硬盘)读取到内存中为输入,数据由内存到外设(硬盘)为输出

字符流的由来:

字节流可以处理所有数据,最早是没有字符流的,但是由于不同语言产生了多张码表(用于将其语言转为计算机语言即01码,如ascll,GBK等),由于多张码表的麻烦,国际组织便产生一张通用的码表Unicode码表,可以识别中英文等,Java中内置Unicode码表。其特点是无论什么字符都用两个字节表示,导致同一个中文在GBK和Unicode码表中对应的数字结果不同(因为对于编写程序选择不同编码方式会产生乱码),将(字节流+编码表)的组合方式封装为字符流。

简要来说:字节流读取文字字节数据后,不直接操作,而是先查指定的编码表,获取对应的文字,再对这个文字进行操作。简单来说,就是字节流+编码表。

分类
字节流的抽象基类:InputStream,OutputStream

字符流的抽象基类:Reader,Writer

注:由这四个类派生出来的子类名称都是以其父类名作为子类名的后缀,如InputStream的子类FileInputStream,Reader的子类FileReader

命名方式可以看作:该对象的功能+以父类名作为后缀

操作文字数据建议优先考虑字符流,而且要将数据从内存写到硬盘上,要使用字符流中的输出流Writer类,将数据从内存写到硬盘上,硬盘上的数据基本体现是文件,希望找到一个可以操作文件的Writer,即FileWriter

既然是往一个文件中写入文字数据,那么在创建对象时,必须明确该文件(用于存储数据的目的地),如果文件不存在,则会自动创建;如果文件存在,则会被覆盖,由于文件路径可能是非法路径,会导致IO异常,因此在方法处抛出,即throws
IOException

构造函数

FileWriter(String fileName):根据给定的文件名构造一个FileWriter对象

FileWriter(String fileName,boolean
append):根据给定的文件名以及指示是否附加(续写)写入数据的boolean值来构造FileWriter对象,构造函数中加入true,可以实现对文件进行续写,不然第二次运行程序会删除原有内容,续写,即可以再次运行写入时,是在原有的基础上基础写入,原内容是保存的

flush()与close()区别:

flush()方法:刷新该流的缓冲,如果该流已保存缓冲区中各种write()方法的所有字符,则立即将它们写入预期目标。然后,

如果该目标是另一个字符或字节流,则将其刷新。因此,一次flush()调用将刷新Writer和OutputStream链中的所有缓冲区,因此上述写入也可以:

close()关闭流,关闭资源。在关闭前会先调用flush刷新缓冲中的数据到目的地

与flush()的区别:flush可以使用多次,不断写入不断刷新即可,而close只可以使用一次,关闭之后,不可以进行流操作。
形象比喻:在一个文档中写数据,每保存一次就相当于进行一次flush(不保存并没有写入硬盘);如果一直写不保存,写完之后关闭,进行一次保存,写入硬盘,相当于close,再打开文件操作时,是另一个流。

换行问题

并不能实现换行,windows中的换行是\r,unix中换行是\n,因此需要,还有一种与系统无关的换行方式:

进行读取有两种方式,一种是read()方法,一种是read(char[] cbuf)方法,如下将分别介绍两种方法:

public int read() throws IOException:

读取单个字符,在字符可用,发生I/O错误或者已到达流的末尾前,此方法一直阻塞

返回:作为整数读取的字符,范围在0到65535之间,如果已到达流的末尾,则返回-1

运行结果:

原理:

基于如上原理可以如下进行连续读取,即连续读取数据的第一种方式,一次读一个

public int read(char[] cbuf) throws IOException:

将字符读入数组。在某个输入可用,发生I/O错误或者已到达流的末尾前,此方法一直阻塞
参数:
cbuf-目标缓冲区
返回:

读取的字符数(不同于read()方法,read()方法返回的是读到的字符),商务英语前景如果已到达流的末尾,则返回-1

不同于read(),read(char[] cbuf)是每读取一个便将其存与数组cbuf中

原理:

基于第二种读取方式的连续读取:

两种读取方式哪种好?

第二种读取所需的循环次数少,效率高,第一种方式有多少个字符就需要循环多少次

两个流(输入流fr与输出流fw)原本是没有关系的,想要使两者能够进行数据传输,需要通过一个“中转”即上述的数组容器

IO流学习笔记(一)之FileWriter与FileReader的更多相关文章

  1. JAVA.IO流学习笔记

    一.java.io 的描述 通过数据流.序列化和文件系统提供系统输入和输出.IO流用来处理设备之间的数据传输 二.流 流是一个很形象的概念,当程序需要读取数据的时候,就会开启一个通向数据源的流,这个数 ...

  2. IO流学习笔记(二)之BufferedWriter与BufferedReader及实例Demo

    在之前的学习笔记(http://blog.csdn.net/megustas_jjc/article/details/72853059)中,FileWriter与FileReader的Demo使用的中 ...

  3. IO流学习笔记

    1.File类 文件和目录路径名的抽象表示形式. 4种构造方法 File(File parent, String child) File(File parent, String child) File ...

  4. Java IO流学习总结(1)

    Java IO流学习总结 Java流操作有关的类或接口: Java流类图结构: 流的概念和作用 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本 ...

  5. Java IO流学习总结四:缓冲流-BufferedReader、BufferedWriter

    在上一篇文章中Java IO流学习总结三:缓冲流-BufferedInputStream.BufferedOutputStream介绍了缓冲流中的字节流,而这一篇着重介绍缓冲流中字符流Buffered ...

  6. Java IO流学习总结一:输入输出流

    Java IO流学习总结一:输入输出流 转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/54292148 本文出自[赵彦军的博客] J ...

  7. Java IO流学习

    Java IO流学习 Java流操作有关的类或接口: Java流类图结构: 流的概念和作用 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是 ...

  8. Java IO流学习总结三:缓冲流-BufferedInputStream、BufferedOutputStream

    Java IO流学习总结三:缓冲流-BufferedInputStream.BufferedOutputStream 转载请标明出处:http://blog.csdn.net/zhaoyanjun6/ ...

  9. Java IO流学习总结八:Commons IO 2.5-IOUtils

    Java IO流学习总结八:Commons IO 2.5-IOUtils 转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/550519 ...

随机推荐

  1. 构建前端第9篇之(上)---Vue组件引入,使用

    张艳涛写于2020-1-25日 一.想写下vue引入组件和插件的理解 今天是星期一,周末也看俩两天,在这个几天了,比较迷,主要是从开始学习import指令开始的,import 是es6的语法, imp ...

  2. sessionfilter中的拦截项判断

  3. 大数据学习(11)—— Hive元数据服务模式搭建

    这一篇介绍Hive的安装及操作.版本是Hive3.1.2. 调整部署节点 在Hadoop篇里,我用了5台虚拟机来搭建集群,但是我的电脑只有8G内存,虚拟机启动之后卡到没法操作,把自己坑惨了. Hive ...

  4. 声明提前(hoist)

    程序执行前,都会先找到var声明的变量和function声明的函数. 一.var声明的变量 程序 结果 console.log(a); var a=10; console.log(a); //unde ...

  5. 《手把手教你》系列技巧篇(十四)-java+ selenium自动化测试-元素定位大法之By xpath上卷(详细教程)

    1.简介 按宏哥计划,本文继续介绍WebDriver关于元素定位大法,这篇介绍定位倒数二个方法:By xpath.xpath 的定位方法, 非常强大.  使用这种方法几乎可以定位到页面上的任意元素. ...

  6. DNS反向解析,主从服务器,分离解析(内外网)

    目录 实验一:DNS反向解析 1.安装bind 2.查找配置文件路径 3.配置/etc/named.conf主配置文件 4.修改/etc/named.rfc1912.zones区域配置文件(复制两个) ...

  7. 对HashMap的一次记录

    HashMap的具体学习,认识了解. 前言 也是最近开始面试才发现,HashMap是问的真多.以前听学长或自己在网上看到过一些面试资料都在说集合.线程这块比较重要,面试的重点.自己也是有那抵触情绪,所 ...

  8. 如何将fidd上抓的包移到jmete中

    1.fiddler的安装配置就不说了, 网上有很多资源, 不会太难 2.使用fiddler抓包, 相信进来看这篇文章的博友都已经会使用fiddler抓包 3.打开jmeter, 添加>测试计划& ...

  9. HDFS总结

    hadoop分布式文件存储系统,用来解决海量数据的存储问题 HDFS的组成------核心配置文件:hdfs-site.xml.core-site.xml NameNode:负责整个HDFS集群的管理 ...

  10. bat脚本中%~dp0含义解释

    在Windows脚本中,%i类似于shell脚本中的$i,%0表示脚本本身,%1表示脚本的第一个参数,以此类推到%9,在%和i之间可以有"修饰符"(完整列表可通过"for ...