在开发本次项目中,我们使用流的方式对存在服务器磁盘的文件进行加载。之前在编写这类代码时,我直接搜索复制粘贴,并未搞懂其真正的原理,本次在搭建文档管理系统(以下简称为DOCMS,其是项目中的子系统,用于控制项目中文件的存储以及通过数据库给定的文件路径以及授权密钥加载文件)时,特意对这部分知识进行了补充。下面我们就Java API中提供的输入流与输出流进行详细分析。
从Java API中,我们可以看出InputStream作为所有输入流的基类(或超类,或父类,这里叫法不一样,通常我们可以理解为所有输入流的老大),OutputStream作为所有输出流的基类,其下有各类具体用途的子类(此处仅分析IO包下的类),如下图所示。
字节流
在DOCMS中,我们目前仅使用了字节流中的两个重要的流,FileInputStream和FileOutputStream,这里我们仅对FileInputStream做分析。
FileInputStream类可以将文件的内容作为字节流读取。Java API提供了三种构造方法用来创建对象。从FileInputStream源码来看,三个构造方法最终都是使用FileDescriptor文件描述符来作为参数的构造器,无论是使用字符串类型的文件名还是使用File类对象,最终都是利用文件描述符来建立连接。
public FileInputStream(String name) throws FileNotFoundException
//使用File对象来创建对象
public FileInputStream(File file) throws FileNotFoundException
//使用文件描述符来作为参数建立连接
public FileInputStream(FileDescriptor fdObj)
public class RSD_InputStream {
public static void main(String[] args) {
try {
InputStream is = new FileInputStream("D:/fileInputStream.txt");
} catch (FileNotFoundException e) {
System.out.println("连接文件发生异常!");
}
}
}
FileInputStream类中定义了众多的API,接下来我们对常用的做简单介绍。
* 从输入流中读取下一个数据字节,返回范围为-1~255,其中有数据则返回0~255,
* 若到达流的末尾,则返回-1
*/
public int read() throws IOException
/**
* 从输入流中读取一些字节数并将它们存储到缓存区数组b中,它最终实现是通过调用read的重载方法。
* 实际读取的字节数以整数形式返回,若b的长度为0,则不读取任何字节,返回0;
* 否则,尝试读取至少一个字节。若到达流末尾,则返回-1,否则至少读取一个字节并存储到b中。
*/
public int read(byte[] b) throws IOException
/**
* 将输入流中最多len个字节的数据读入一个字节数组。
* @param b 读取数据的缓冲区
* @param off 数组b中写入数据的起始偏移量
* @param len 要读取的最大字节数
*/
public int read(byte[] b, int off, int len) throws IOException
public class RSD_InputStream {
public static void main(String[] args) {
try {
InputStream is = new FileInputStream("D:/fileInputStream.txt");
System.out.println(is.read());
System.out.println(is.read(new byte[2]));
System.out.println(is.read(new byte[10], 0, 8));
} catch (FileNotFoundException e) {
System.out.println("连接文件发生异常!");
} catch (IOException e) {
e.printStackTrace();
}
}
}
//控制台值
72
2
8
网友评论