IO流-概览
一、 ?? 抽象类InputStream和OutputStream构成了了IO类的基础 ?? 因为面向字节流的对象不便于处理Unicode形式储存的信息,所以从抽象类Reader和Writer中继承出专门用于处理Unicode字符的类构成了一个单独的层次结构 ?? 这些类拥有的读入和写出操作都是基于两字节的Unicode码元的。 ?? 二、 ?? 每个子类只需覆盖InputStream中read方法(读入一个字节)或者是OutputStream中write方法(向某个位置写出一个字节) ?? read和write在执行时都将阻塞,直至字节确实被读入或写出,如果流不能被立即访问则该线程阻塞(可通过available方法判断可用于读入的字节数量来避免阻塞) ?? ?? API: ????? java.io.InputStream: ????? (1)abstract int read():从数据中读入一个字节,并返回该字节,在碰到流的尾时返回-1 ????? (2)int read(byte[] b):读入一个字节数组,返回实际读入的字节数,最多读入b.length个字节,在碰到流的尾时返回-1 ????? (3) int read(byte[] b,int off,int len):读入一个字节数组。这个read方法返回实际读入的字节数,或者在碰到流的结尾时返回-1 ???????? 参数:b 数据读入的数组 ??????????? off 第一个读入字节应该被放置的位置在b中的偏移量 ??????????? len 读入字节的最大数量 ????? (4) long skip(long n):在输入流中跳过n个字节,返回实际跳过的字节数(如果碰到流的结尾,则可能小于n) 。 ????? (5) int available():返回在不阻塞的情况下可用的字节数(阻塞意味着当前线程将失去它对资源的占用) 。 ????? (6) void close():关闭流 ????? (7) void mark(int readlimit):在输入流的当前位置打一个标记(并非所有的流都支持这个特性) 。如果从输入流中已经 ???????? 读入的字节多于readlimit个,则这个流允许忽略这个标记。 ????? (8)void reset():返回到最后的标记,随后对read的调用将重新读入这些字节。如果当前没有任何标记, ???????? 则这个流不被重置。 ????? (9)boolean markSupported():如果这个流支持打标记,则返回true。 ????? ????? java.io.OutputStream: ????? (1) abstract void write(int n):写出一个字节的数据。 ????? (2) void write(byte[] b) ????? (3) void write(byte[] b,int len):写出所有字节或者某个范围的字节到数组b中 ???????? 参数:b 数据写出的数组 ??????????? off 第一个写出字节在b中的偏移量 ??????????? len 写出字节的最大数量 ????? (4) void close():清空并关闭输出流。 ????? (5)? void flush():清空输出流,也就是将所有缓冲的数据发送到目的地 ????? ? 三、流家族: (一)字节流家族: ? (二)Unicode文本流家族 ? 四、组合流过滤器: FileInputStream和FileOutputStream只能从文件中读入字节或者字节数组(不能读入数字类型),而DataInputStream只能读入数字类型(不能从文件中获取数据),那么可以组合这两个类从文件中读取数字: FileInputStream fin = new FileInputStream(“test.txt”); DataInputStream din = new DataInputStream(fin); Double s = din.readDouble(); ? 流在默认情况下是不进缓冲区的,那么我们可以这样组合: DataInputStream din = new DataInputStream( New BufferedInputStream( New FileInputStream(“test.txt”)));(之所以把datainputsteam放在最后是为了使用DataInputStream的方法,并且希望它们能够使用带缓冲机制的read方法) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |