Java流
流是一组有顺序的,有起点和终点的字节集合,是对传输数据的总称或抽象。即数据在两设备间的传输称为流,流的本质是传输数据,依据传输数据特性将流抽象为各种类,方便更直观的进行数据操作。
流的分类:
数据类型:字节流、字符流
数据方向:输入流、输出流
数据功能:节点流、处理流
流的四个抽象类:
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流,须要自己很多其它的去体会和理解。
Java流的更多相关文章
- 登堂入室——java流
——文章出自PeterYe,不得私自转载 我所知道的 java.io里面的[流],就仿佛太平洋里面的水一样,浩浩荡荡,横无际涯... -----2016/7/16--------公寓处记录------ ...
- Java笔记:Java 流(Stream)、文件(File)和IO
更新时间:2018-1-7 12:27:21 更多请查看在线文集:http://android.52fhy.com/java/index.html java.io 包几乎包含了所有操作输入.输出需要的 ...
- java 流输出的一些问题
一.java流的控制首先要先准备一个文件,例如:File f = new File(d:/lol.txt); 二.可以使用如下指令创建流,用于不同的用途 1.FileInputStream,FileO ...
- JAVA流式布局管理器--JAVA基础
JAVA流式布局管理器的使用: FlowLayoutDeme.java: import java.awt.*;import javax.swing.*;public class FlowLayoutD ...
- Java - 17 Java 流(Stream)、文件(File)和IO
Java 流(Stream).文件(File)和IO Java.io包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io包中的流支持很多种格式,比如:基本类型. ...
- Java总结:Java 流(Stream)、文件(File)和IO
更新时间:2018-1-7 12:27:21 更多请查看在线文集:http://android.52fhy.com/java/index.html java.io 包几乎包含了所有操作输入.输出需要的 ...
- java 流 文件 IO
Java 流(Stream).文件(File)和IO Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类 ...
- 使用Socket&反射&Java流操作进行方法的远程调用(模拟RPC远程调用)
写在前面 阅读本文首先得具备基本的Socket.反射.Java流操作的基本API使用知识:否则本文你可能看不懂... 服务端的端口监听 进行远程调用,那就必须得有客户端和服务端.服务端负责提供服务,客 ...
- 深入理解Java流机制(一)
一.前言 C语言本身没有输入输出语句,而是调用"stdio.h"库中的输入输出函数来实现.同样,C++语言本身也没有输入输出,不过有别于C语言,C++有一个面向对象的I/O流类库& ...
随机推荐
- 构建自己的Java并发模型框架
Java的多线程特性为构建高性能的应用提供了极大的方便,可是也带来了不少的麻烦.线程间同步.数据一致性等烦琐的问题须要细心的考虑,一不小心就会出现一些微妙的,难以调试的错误. 另外.应用逻辑和线程逻辑 ...
- 源码安装apache及配置转发
一. 安装Apache a) 解压:tar -xvf httpd-*; b) ./configure --prefix=/usr/oracle/apache CC="gcc ...
- OS调度算法常用摘要
一.常见的批处理作业调度 1.先来先服务调度算法(FCFS):就是依照各个作业进入系统的自然次序来调度作业.这样的调度算法的长处是实现简单,公平. 其缺点是没有考虑到系统中各种资源的综合使用情况,往往 ...
- SlopOne推荐算法
在开源框架taste中有SlopOne的Java实现,效果不错.使用movielens的数据,代码例如以下 代码 #coding:utf-8 import re import math #读取数据,并 ...
- 生活中的大数据 hadoop
大数据和我有关吗?大数据就是大量的数据吗?只有互联网公司才有大数据吗?想盘活大数据必须买昂贵的软硬件吗?大数据怎么存储计算?大数据,这个时下最火热的互联网词语,你了解多少呢?
- Error 56: The Cisco Systems, Inc. VPN Service has not been started(Cisco VPN在Vista下出现Error 56的解决办法)
Error 56: The Cisco Systems, Inc. VPN Service has not been started(Cisco VPN在Vista下出现Error 56的解决办法) ...
- T-SQL基础(4) - 子查询
简单子查询select * from (select custid, companyname from Sales.Customers where country = N'USA') as USACu ...
- Atitit.列表页and查询条件的最佳实践(1)------设定搜索条件and提交查询and返回json数据
Atitit.列表页and查询条件的最佳实践(1)------设置查询条件and提交查询and返回json数据 1. 1. 配置条件字段@Conditional 1 1 2. 2. 配置条件字段显示类 ...
- Codeforces 9A-Die Roll(意甲冠军)
A. Die Roll time limit per test 1 second memory limit per test 64 megabytes input standard input out ...
- node.js基础:数据存储
无服务器的数据存储 内存存储 var http = require('http'); var count = 0; //服务器访问次数存储在内存中 http.createServer(function ...