侠义的上讲,就是从本地硬盘上的某个文件中进行读取数据。
2、写入流:output侠义的讲,就是把一个文件或者一个集合或者数组以及字符串等等一些数据, 向磁盘中某个文件中进行写或者说注入
二、从流的组织形式上可以划分为字节流和字符流 因为计算机中最小的存储单元为字节,另外因为不同国家和地区的语言不同 用的字符编码方式也就不同,所以字符流也应景而出。不同的字符在计算机内存和和硬盘上存储的大小也是不相同的例如:我们常见的英文字母以及符号和数字等在计算机和其他字符编码集中,这些常见的字符在计算机底层中所占用的字节数目都是相等的也就是1个字节,在常见的编码表中例如UTF-8、GBK/等都兼容了ASCII码中这些常见的字符集,但是中文在GBK编码方式中,一个中文就只
占用2个字节,而在UTF-8中常见的中文可能就占用3个字节,不常用的占用可能达到了4个字节。这就带来了一个问题,数据在不同的操作系统上或者环境中,可能是不同的编码方式,那么有没有一种方式能够让数据根据不同的操作系统或者我当前系统环境中的字符编码,方式自主选择呢,这样就不会带来,数据在传输过程中因为编码方式的不同造成乱码的情况。
所以说我们一般在传输音频和图片以及压缩包等文件的时候,在程序猿的世界中 都会采用字节流,一方面是因为字符流处理不了这些音视频文件,另外的一个重要的原因就是因为这些压缩包中可能存在中文字符和其他文字字符,在传输的过程中可能会导致乱码。
下面我们将主要介绍字符流和字节流,不会着重介绍例如像缓冲流、打印流等
其中的一个主要原因缓冲流提升性能的效率实在有限,我们一般是采用字节数组或
者字符数组的方式组织数据的传输。
举例: 文件拷贝, 文件上传下载
输入流 : input (输入读取)
输出流 : output (输出写出)
2. 按照类型分
往下看- 字节流
问题: 什么时候用字节流
回答: 操作非纯文本文件的时候, 全用字节流
InputStream (抽象类)
-| FileInputStream (普通字节输入流)
-| BufferedInputStream (缓冲字节输入流)
OutputStream (抽象类)
-| FileOutputStream (普通字节输出流)
-| BufferedOutputStream (缓冲字节输出流)
-| PrintStream (打印流)
使用场景 :
FileInputStream FileOutputStream
拷贝文件(加入自定义数组的拷贝)
BufferedInputStream BufferedOutputStream |
复习的时候, 不需要投入大量时间
很少使用(效率在拷贝的时候, 没有提升太多)
PrintStream (不常使用)
写出一些数据, 希望有换行效果(还不想手写换行代码)
- 字符流
问题: 什么时候用字符流?
回答: 操作纯文本文件的时候, 为了避免中文乱码问题, 可以使用字符流
字符流 : 字节流 + 编码表
- ASCII : 最基础的码表, 所有的码表, 都囊括了ASCII
- GBK : 中国的码表, 没有韩文...
一个中文占用2个字节
- Unicode(UTF-8) : 万国码, 一个中文占用3个字节
- 数字, 标点, 英文 ---> 占用1个字节
- 中文 : 第一个字节肯定是负数, 后面有可能是正数
字符流读取中文, 解决乱码问题的原理 :
字符流在读取的时候, 也是先读取的字节, 会先读取第一个字节, 判断是否是负数
负数 : 代表读取到了中文, 结合平台默认的编码表, 决定读取几个
GBK : 读取两个, 再进行转换
UTF-8 : 读取三个, 在进行转换
正数 : 代表读取的不是中文, 读取一个字节, 然后进行转换
总结 : 字符在读写数据的时候, 内部会进行判断和转换, 如果你拷贝文件,
不要使用字符流



