Java中IO操作主要是指使用Java进行输入,输出操作,Java中所有的IO操作类都存放在Java.io包中,在使用时需要导入此包。

在整个Java.io包中最重要的就是5个类和一个接口。5个类指的是File,InputStream,OutputStream,Reader,Writer,分别用来进行文件操作,输入输出字节流,输入输出字符流操作,一个接口指的是Serializable,用来将对象进行序列化,然后使用ObjectInputStream/ObjectOutputStream对象输入输出流进行读写。

一java.io包中流的分类:

按照数据流方向的不同可以分为输入流和输出流。

按照按照数据处理单位的不同可以分为字节流和字符流。

因此两两组合供四种情况,如下所示:

其中,InputStream是所有输入字节流的基类,Reader是所有输入字符流的基类,OutputStream是所有输出字节流的基类,Writer是所有输出字符流的基类。其中字节流可用来处理任何类型的数据,如文本,图片,视频,音乐,而字符流一般用来处理文本,尤其是像中文这样的宽字节语言。

二各种IO详解

1 InputStream:为字节输入流,它本身为一个抽象类,必须依靠其子类实现各种功能,此抽象类是表示字节输入流的所有类的超类。 继承自InputStream  的流都是向程序中输入数据。

常用的方法:

public int read()

读取一个字节,以整数形式返回

如果读取到输入流的末尾则返回-1

public int read(byte[] buffer)

从输入流中读取一定数量的字节,将其存储在缓冲数组buffer中,以整数形式返回实际读取到的字节数

如果读取到输入流的末尾则返回-1

public int read(byte[] buffer,int off,int len)

从输入流中最多读取len各字节存放到buffer数组中

off表示将读取到第一个字节的数据存储到buffer[off]处,即在buffer数组中存放数据的起始位置

该函数尝试读取len各字节的数据,但可能读取到的数据小于len,以整数形式返回实际读取到的字节数

如果读取到输入流的末尾则返回-1

其类的继承体系如下:

其中重点掌握FileInputStream,BufferInputStream,ByteArrayInputStream,ObjectInputStream

FileInputStream:先来看看它的构造器:

(1)FileInputStream(File fileName) 创建一个输入文件流,从指定的 File 对象读取数据。

(2)FileInputStream(FileDescriptor fdName) 创建一个输入文件流,从指定的文件描述器读取数据。

(3)-FileInputStream(String  name) 创建一个输入文件流,从指定名称的文件读取数据。

FileInputStream通常用作文件与其它装饰流之间转换的桥梁,因为装饰流的的构造器的参数一般为InputStream,而FileInputStream为InputStream的子类且其构造器的参数一般为File。

ByteArrayInputStream:把内存中的一个缓冲区作为 InputStream 使用 .

先来看看它的构造器:

(1)ByteArrayInputStream(byte[]) 创建一个新字节数组输入流( ByteArrayInputStream ),它从指定字节数组中读取数据( 使用 byte 作为其缓冲区数组)

(2)ByteArrayInputStream(byte[], int, int) 创建一个新字节数组输入流,它从指定字节数组中读取数据。

正因为ByteArrayInputStream是把内存中的一个缓冲区用作inputStream,所以常用来用作内存缓冲,如在安卓中常常用来解析一个BitMap图片,代码如下:

private Bitmap decodeBitmap(Bitmap bitmap) {
int scale = 100;
ByteArrayOutputStream bos = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, scale, bos);
while ((bos.toByteArray().length / 1024) > 30) {
bos.reset();
bitmap.compress(Bitmap.CompressFormat.JPEG, scale, bos);
scale -= 10;
}
ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
bitmap = BitmapFactory.decodeStream(bis);
return bitmap;
}

BufferInputStream:

ObjectInputStream:

先来看看它的构造器:

(1)ObjectInputStream():实例化一个ObjectInputStream对象

(2)ObjectInputStream(InputStream):使用一个InputStream对象来实例化一个ObjectInputStream对象,其中InputStream就是对象的输入流

通常我们使用第二个构造器,用来将一个InputStream包裹为ObjectInputStream,最常用的方式就是在网络中传输对象的时候,让某个对象实现Serializable接口,然后就可以用ObjectInputStream的readObject()从网络中读取该对象

2 .OutputStream:为字节输出流,它本身为一个抽象类,必须依靠其子类实现各种功能,此抽象类是表示字节输出流的所有类的超类。 继承自InputStream  的流都是从程序中输出数据。

常用的方法:

public void write(int buffer) 向输出流中写入一个字节的数据

public void write(byte[] buffer)将字节型数组buffer中的数据写入到输出流中

public void read(byte[] buffer,int off,int len)将字节型数组buffer从指定位置off开始的len个字节数据写入到输出流中

其类的继承体系如下:

其中重点掌握FileoutputStream,BufferOutputStream,ObjectoutputStream

FileoutputStream:

BufferOutputStream:

ObjectoutputStream:

以上三种类的所有用法与其对应的InputStream完全相同,只不过将read该为了write。

3Reader:为字符输入流,它本身为一个抽象类,必须依靠其子类实现各种功能,此抽象类是表示字符输入流的所有类的超类。 继承自Reader的流都是从源中读取数据。其类的继承体系如下:

其中重点掌握BufferedReader:

先来看看它的构造器:

(1)BufferedReader(Reader in):实例化一个ObjectInputStream对象

(2))BufferedReader(Reader in,int size):BufferReader提供了readLine()方法用于从原源中去读一行字符串

通常用作装饰流,将一个InputStreamReader转换为BufferReader,如在安卓中我们通常会用到该类从网络中获取的数据以字符串的形式保存起来,代码如下:

public static void doGetRequest(final String uri,final HttpCallbackListener listener) throws IOException
{
new Thread(){
public void run ()
{
URL url;
try {
url = new URL(uri);
HttpURLConnection connection=(HttpURLConnection) url.openConnection();
// connection.setDoInput(true);
// connection.setRequestMethod("GET");
connection.connect();//必须加上该语句
InputStream is=connection.getInputStream();
BufferedReader reader=new BufferedReader(new InputStreamReader(is));//使用BufferedReader从网络中读取字符串
StringBuilder buffer=new StringBuilder();
String line;
while((line=reader.readLine())!=null)
{
buffer.append(line); }
if(listener!=null)
{ listener.onComplete(buffer.toString());
}
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
}.start(); }

InputStreamReader:通常与BufferReader联合使用,具体使用情况如上BufferReader所示。

4Writer:为字符输出流,它本身为一个抽象类,必须依靠其子类实现各种功能,此抽象类是表示字符输出流的所有类的超类。 继承自Writer的流都是向目的地写入数据。其类的继承体系如下:(注意下图,第三个应该为OutputStreamWriter)

其中重点掌握BufferedWriter:

OutputStreamWriter

以上两个类的所有用法与其对应的Reader完全相同,只不过将read改为了write,因此不再赘述。

JavaI/O体系详解的更多相关文章

  1. Java集合中List,Set以及Map等集合体系详解

    转载请注明出处:Java集合中List,Set以及Map等集合体系详解(史上最全) 概述: List , Set, Map都是接口,前两个继承至collection接口,Map为独立接口 Set下有H ...

  2. 20160226.CCPP体系详解(0036天)

    程序片段(01):01.多线程.c+02.多线程操作.c 内容概要:多线程 ///01.多线程.c #include <stdio.h> #include <stdlib.h> ...

  3. 20160208.CCPP体系详解(0018天)

    程序片段(01):main.c 内容概要:PointWithOutInit #include <stdio.h> #include <stdlib.h> //01.野指针详解: ...

  4. 20160206.CCPP体系详解(0016天)

    代码片段(01):.指针.c+02.间接赋值.c 内容概要:内存 ///01.指针 #include <stdio.h> #include <stdlib.h> //01.取地 ...

  5. 20160205.CCPP体系详解(0015天)

    程序片段(01):01.杨辉三角.c 内容概要:杨辉三角 #include <stdio.h> #include <stdlib.h> #define N 10 //01.杨辉 ...

  6. 20160204.CCPP体系详解(0014天)

    程序片段(01):define.h+data.h&data.c+control.h&control.c+view.h&view.c+AI.h&AI.c+main.c 内 ...

  7. 20160203.CCPP体系详解(0013天)

    程序片段(01):数组.c+02.数组初始化语法.c 内容概要:数组 ///01.数组.c #include <stdio.h> #include <stdlib.h> //0 ...

  8. 20160129.CCPP体系详解(0008天)

    程序片段(01):函数.c+call.c+测试.cpp 内容概要:函数 ///函数.c #include <stdio.h> #include <stdlib.h> //01. ...

  9. 20160128.CCPP体系详解(0007天)

    以下内容有所摘取,进行了某些整理和补充 论浮点数的存储原理:float浮点数与double浮点数的二进制存储原理–>阶码 浮点数转二进制 1.整数int类型和浮点数float类型都是占用4个字节 ...

随机推荐

  1. UDA机器学习基础—交叉验证

    交叉验证的目的是为了有在训练集中有更多的数据点,以获得最佳的学习效果,同时也希望有跟多的测试集数据来获得最佳验证.交叉验证的要点是将训练数据平分到k个容器中,在k折交叉验证中,将运行k次单独的试验,每 ...

  2. python3全栈开发-补充UDP的套接字、操作系统、并发的理论基础

    一.基于UDP的套接字 udp套接字简单示例 import socket ip_port=('1.1.1.1',8181) BUFSIZE=1024 udp_server_client=socket. ...

  3. a++与 ++a

    a++先执行表达式再自增执行表达式使用a原值++a先自增再执行表达示执行表达式使用自增a例:int a=0printf("%d",a++); //输0,执行完a=1int a=0p ...

  4. Python从入门到实践 学习笔记(二)元祖686gffs

    列表是可以修改的,而不可变的列表被称为元组 . 定义 * 用圆括号来标识.定义元组后,使用索引来访问其元素,就像访问列表元素一样 修改变量 * 不能修改元组的元素,但可以给存储元组的变量赋值 修改元素 ...

  5. Flexible DEMO 实现手淘H5页面的终端适配

    <!DOCTYPE html> <html> <head> <title>淘宝flexiblejs</title> <meta cha ...

  6. 项目中BigDecimal与Double使用场景

    金额要用BigDecimal 金额计算不能用doube!!!! 金额计算必须用BigDecimal,下面对比一下用double 跟BigDecimal的区别.先看一个小例子: 请看题: 示例1 问, ...

  7. Python小代码_4_省市区三级菜单

    menu = { "北京": { "朝阳区": { "三环到四环之间": {}, "四环到五环之间": {}, &quo ...

  8. 77. Combinations(medium, backtrack, 重要, 弄了1小时)

    Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. For exampl ...

  9. 什么样的简历受HR青睐?

    简历是我们在求职过程中的名片,那么如何写出更容易受到HR青睐的简历呢? HR可能一天要看上百份的简历,他们都希望能够尽快筛选出合适的人,然后用更多的时间去跟候选人沟通.所以招聘人员一般看一份简历只会花 ...

  10. Jupyter Notebook 添加目录

    1.  安装 jupyter_contrib_nbextensions pip install jupyter_contrib_nbextensions 2. 配置 nbextension jupyt ...