javaIO 流分析总结
来源:互联网 发布:淘宝买港版苹果手机 编辑:程序博客网 时间:2024/06/05 09:46
Java中的流,可以从不同的角度进行分类。
按照数据流的方向不同可以分为:输入流和输出流。
按照处理数据单位不同可以分为:字节流和字符流。
按照实现功能不同可以分为:节点流和处理流。
输出流:
输入流:
因此输入和输出都是从程序的角度来说的。
字节流:一次读入或读出是8位二进制。
字符流:一次读入或读出是16位二进制。
字节流和字符流的原理是相同的,只不过处理的单位不同而已。后缀是Stream是字节流,而后缀是Reader,Writer是字符流。
节点流:直接与数据源相连,读入或读出。
直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。
处理流:与节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。
Jdk提供的流继承了四大类:InputStream(字节输入流),OutputStream(字节输出流),Reader(字符输入流),Writer(字符输出流)。
以下是java中io中常用的流。
字节输入流:
字节输出流:
字符输入流:
字符输出流:
简单介绍其上图:
对文件进行操作:FileInputStream(字节输入流),FileOutputStream(字节输出流),FileReader(字符输入流),FileWriter(字符输出流)
对管道进行操作:PipedInputStream(字节输入流),PipedOutStream(字节输出流),PipedReader(字符输入流),PipedWriter(字符输出流)
PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操作。主要用于线程操作。
字节/字符数组:ByteArrayInputStream,ByteArrayOutputStream,CharArrayReader,CharArrayWriter是在内存中开辟了一个字节或字符数组。
Buffered缓冲流::BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter,是带缓冲区的处理流,缓冲区的作用的主要目的是:避免每次和硬盘打交道,提高数据访问的效率。
转化流:InputStreamReader/OutputStreamWriter,把字节转化成字符。
数据流:DataInputStream,DataOutputStream。
因为平时若是我们输出一个8个字节的long类型或4个字节的float类型,那怎么办呢?可以一个字节一个字节输出,也可以把转换成字符串输出,但是这样转换费时间,若是直接输出该多好啊,因此这个数据流就解决了我们输出数据类型的困难。数据流可以直接输出float类型或long类型,提高了数据读写的效率。
打印流:printStream,printWriter,一般是打印到控制台,可以进行控制打印的地方。
对象流:ObjectInputStream,ObjectOutputStream,把封装的对象直接输出,而不是一个个在转换成字符串再输出。
序列化流:SequenceInputStream。
对象序列化:把对象直接转换成二进制,写入介质中。
使用对象流需要实现Serializable接口,否则会报错。而若用transient关键字修饰成员变量,不写入该成员变量,若是引用类型的成员变量为null,值类型的成员变量为0.
- javaIO 流分析总结
- JavaIO流分析总结
- javaIO流学习总结
- javaIO流总结
- javaIO流总结
- javaIO 流学习总结
- javaIO流总结
- javaIO流部分总结
- javaIO流接口总结
- 个人总结 javaIO流
- JavaIO流的总结!
- JavaIO-JavaIO总结
- 【SanSui】javaIO各种流分析
- javaIO总结一(输入输出流)
- javaIO流的学习总结
- 黑马程序员-----javaIO流总结*
- javaIO流操作规律总结
- JavaIO输入输出流的总结
- MYSQL数据库简单的状态检查(show processlist)
- 简介python装饰器
- 一个正负数组,求其最大的连续子串和
- 三十、组、指针和字符串:指针用作函数参数、指针型函数和函数指针
- 非常全的类库
- javaIO 流分析总结
- _BLOCK_TYPE_IS_VALID(pHead->nBlockUse问题解析
- 排序大汇总
- 进程
- 关于String字符串的一些学习总结
- java方法中需要用到正则表达式的地方
- redis 在linux上安装
- ScrollView
- LeetCode | Unique Paths