流是一组有顺序的,有起点和终点的字节集合,是对传输数据的总称或抽象。即数据在两设备间的传输称为流,流的本质是传输数据,依据传输数据特性将流抽象为各种类,方便更直观的进行数据操作。

流的分类:

数据类型:字节流、字符流

数据方向:输入流、输出流

数据功能:节点流、处理流

流的四个抽象类:

J2SDK所提供的全部流类型位于包java.io内部,分别继承自一下四种抽象流类型。

InputStream 、OutputStream、Reader、Writer

当中InputStream和OutputStream是字节流,处理的时候是通过输入或输出字节形式的;Reader和Writer是通过字符来处理的,读取或写入每一个字符。在java中输入输出写入读取是从程序的方向上去辨别的。

那么什么是节点流和处理流呢?

节点流:从一个特定的数据源读写数据,这个数据源能够使文件、内存等。

处理流:是连接在已经存在的流(节点流或者处理流)之上,通过对数据的处理为程序提供更加强大的读写功能。

举个样例:比方说我们从某个文件里读取数据我们把这个文件当做一个大桶,我们如今用个管道直接连接在这个大桶上进行抽水此时这根管道就是节点流;当我们感觉这个管道不够我们抽水用的了,我们在其外面套上一个大的抽水管道,此时这个大的管道就相当于处理流。

InputStream和OutputStream

 

Reader和Writer

实例一:

以以下两个实例来分析这四个抽象类。

用FileInputStream与FileOutputStream,能够拷贝文件,即它会先从来源文件b.txt读取数据至一个byte数组中,然后再将byte数组的数据写入目的文件a.txt。

先在D盘根文件夹下建立两个a.txt和b.txt,在b.txt中写入“Java学习之旅!!!”,然后建立程序:

import java.io.*;
public class Demo {
public static void main(String[] args) {
try {
// 来源文件
FileInputStream in = new FileInputStream("D:/b.txt");
// 目的文件
FileOutputStream out = new FileOutputStream("D:/a.txt");
byte[] bytearray = new byte[1024];
do {
in.read(bytearray, 0, 1024);
out.write(bytearray);
} while (in.available() > 0);
in.close();
out.close();
} catch (ArrayIndexOutOfBoundsException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

执行此程序后,打开a.txt,你会发现a.txt同b.txt一样。

程序中示范了两个read()方法,一个方法能够读入指定长度的数据至数组,还有一个方法一次能够读入一个字节.每次读取之后,读取的光标都会往前进,假设读不到数据刚返回-1.使用available()方法能够获得还有多少字节能够读取。

  在不使用文件流时,记得使用close()方法自行关闭流,以释放与流相依的系统资源。

  FileOutputStream默认会以新建文件的方式来开启流。假设指定的目标文件名已经存在,则会被覆盖目标文件,即此时的a.txt。

  FileInputStream读取文件时,假设此时源文件不存在,则会提示文件不存在,即提示b.txt不存在。

实例二:

实现效果与上例同样

IO流中的BufferedInputStream与BufferedOutputStream能够为InputStream、OutputStream类的对象添加缓冲区功能,构建BufferedInputStream实例时,须要给定一个InputStream类型的实例,实现BufferedInputStream时,实际上最后是实现InputStream实例。相同地,在构建BufferedOutputStream时,也须要给定一个OutputStream实例,实现BufferedOutputStream时,实际上最后是实现OutputStream实例。

import java.io.*;
public class Demo1 {
public static void main(String[] args) {
try {
// 来源文件
FileInputStream in = new FileInputStream("D:/b.txt");
// 目的文件
FileOutputStream out = new FileOutputStream("D:/a.txt");
BufferedInputStream bufferedIn = new BufferedInputStream(in);
BufferedOutputStream bufferedOut = new BufferedOutputStream(out);
byte[] data = new byte[1];
while (bufferedIn.read(data) != -1) {
bufferedOut.write(data);
}
//将缓冲区中的数据所有写出
bufferedOut.flush();
//关闭流
bufferedIn.close();
bufferedOut.close();
} catch (ArrayIndexOutOfBoundsException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

总结

输入流向从里面读取数据,输出流向当中写入数据,正是有了这些输入和输出流,才有了文件的上传下载,网络的链接,图片的复制粘贴等。java流,须要自己很多其它的去体会和理解。

关于J2SE的总结结束了。下面是我在学习J2SE时的一系列总结。
         Java异常处理
         Java经常使用类
         Java容器
         Java流

Java流的更多相关文章

  1. 登堂入室——java流

    ——文章出自PeterYe,不得私自转载 我所知道的 java.io里面的[流],就仿佛太平洋里面的水一样,浩浩荡荡,横无际涯... -----2016/7/16--------公寓处记录------ ...

  2. Java笔记:Java 流(Stream)、文件(File)和IO

    更新时间:2018-1-7 12:27:21 更多请查看在线文集:http://android.52fhy.com/java/index.html java.io 包几乎包含了所有操作输入.输出需要的 ...

  3. java 流输出的一些问题

    一.java流的控制首先要先准备一个文件,例如:File f = new File(d:/lol.txt); 二.可以使用如下指令创建流,用于不同的用途 1.FileInputStream,FileO ...

  4. JAVA流式布局管理器--JAVA基础

    JAVA流式布局管理器的使用: FlowLayoutDeme.java: import java.awt.*;import javax.swing.*;public class FlowLayoutD ...

  5. Java - 17 Java 流(Stream)、文件(File)和IO

    Java 流(Stream).文件(File)和IO Java.io包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io包中的流支持很多种格式,比如:基本类型. ...

  6. Java总结:Java 流(Stream)、文件(File)和IO

    更新时间:2018-1-7 12:27:21 更多请查看在线文集:http://android.52fhy.com/java/index.html java.io 包几乎包含了所有操作输入.输出需要的 ...

  7. java 流 文件 IO

    Java 流(Stream).文件(File)和IO Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类 ...

  8. 使用Socket&反射&Java流操作进行方法的远程调用(模拟RPC远程调用)

    写在前面 阅读本文首先得具备基本的Socket.反射.Java流操作的基本API使用知识:否则本文你可能看不懂... 服务端的端口监听 进行远程调用,那就必须得有客户端和服务端.服务端负责提供服务,客 ...

  9. 深入理解Java流机制(一)

    一.前言 C语言本身没有输入输出语句,而是调用"stdio.h"库中的输入输出函数来实现.同样,C++语言本身也没有输入输出,不过有别于C语言,C++有一个面向对象的I/O流类库& ...

随机推荐

  1. HDU4960Another OCD Patient(间隙dp,后座DP)

    Another OCD Patient Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Ot ...

  2. [转载]使用python上传图片到 yeelink

    #/bin/env python # -*-coding:utf=8 -*- import os,time,subprocess,shlex import urllib2 def upload_yee ...

  3. js阻止冒泡

    js阻止冒泡 (ev || event).cancelBubble = true; 标签切换 <script type="text/javascript"> windo ...

  4. 关于.net MVC5+EF6 网站部署的问题

    创建mvc web application,采用code first 的方式,MVC5,EF6.0 整了一个网站.开发完之后.直接publish.就这样部署到服务器上了. 在使用过程中发现,网站打开的 ...

  5. 乐在其中设计模式(C#) - 原型模式(Prototype Pattern)

    原文:乐在其中设计模式(C#) - 原型模式(Prototype Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 原型模式(Prototype Pattern) 作者:weba ...

  6. ListView滑动删除 ,仿腾讯QQ

    转载请表明出处:http://blog.csdn.net/lmj623565791/article/details/22961279 在CSDN上开了很多大神们的文章,感觉受益良多,也非常欣赏大家的分 ...

  7. [LeetCode66]Plus One

    题目: Given a non-negative number represented as an array of digits, plus one to the number. The digit ...

  8. Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)(转)

    互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种情况下诞生的.现在核心业务抽取出来,作为独立的服务,使 ...

  9. JAVA card 应用程序开发(七) JAVA 卡数据(永久数据/)时间数据

    JAVA 卡对象 JAVA CARD 存储器装置: a.      ROM: 永久保存程序和数据,虚拟机,API等待:(Applets它也可以在这里放) b.      RAM: 栈数据,暂时对象. ...

  10. FastDFS设备、构造、配置()一-安装和部署

    FastDFS是一个开源的.高性能的的分布式文件系统,他基本的功能包含:文件存储.同步和訪问,设计基于高可用和负载均衡,FastDFS很适用于基于文件服务的站点.比如图片分享和视频分享站点 FastD ...