IO流 总结三

时间:2023-03-09 07:00:40
IO流 总结三

编码:字符串变成字节数组。

解码:字节数组变成字符串

String --> byte[]; str.getBytes();

byte  --> String: new String(bytep[]);

如果编码的时候产生错误,就放弃

如果解码的时候产生错误,就编一次,解一次(通用方法)[对编码的时候用gbk,解码的

时候用utf-8,这种方法不行,因为utf-8会去找相似的字,结果源码就会变掉]

在记事本里输入联通两个字,就会变成乱码,因为这两个字符合联通的编码形式

符合UTF-8的编码规则

没有方法的接口称之为标记接口

FileOutputStream out;

out.write(256) 只是输出最低8位

打开记事本其实是解码的过程

objectInputStream与ObjectOutputStream

被操作的对象需要实现Serizlizable(标记接口); static final long serialVersionUID = 42L;

Serizlizable接口的标签

将堆内存中的对象转化为硬盘上的

所以静态的不能序列化(也称为持久化存储),,在方法区

加关键字transient 也不能序列化

管道流:

PipedInputStream 和PipedOutputStream

输入输出可以直接进行连接,通过结合线程使用

RandomAccessFile

随机访问文件,自身具备读写的方法。

通过skipBytes(int
x),seek (int x) 来达到随机访问

该类不是IO体系中的子类。

而是直接继承来自Object

但是它是IO包中成员,因为它具备读和写功能。

内部封装了一个数组,而且通过指针对数组元素进行操作

可以通过getFilePointer获取指针信息

同时可以通过seek改变指针的位置

其实文成读写的原理就是内部封装了字节输入流和输出流

通过构造函数可以看出,该类只能操作文件

如果模式为只读r,不会创建文件,会去读取一个已存在文件,如果该文件不存在

则会出现异常。

如果模式为rw,操作的文件不存在会自动创建,存在会创建,存在则不会覆盖

通过seek方法,调整对象中指针,a.write(int) 输出的是参数的最低8位,

可以用于操作基本数据类型的流对象

DataInputStream与DataOutputStream 如果以writeUTF只能以对应的方法来读取。不能用转换流,writeUTF用的UTF-8修改版

如果是字节流,存入到记事本里,系统会选择编码表来查,所以都是乱码。

操作基本数据类型

DataInputStream与DataOutputStream

操作字节数组

ByteArrayInpuStream 与

ByteArrayOutputStream

操作字符数组

CharArrayReader与CharArrayWrite

操作字符串

StringReader与StringWriter

ByteArrayInputStream: 在构造的时候,需要接收数据源,而且数据源是一个字节数组

ByteArrayOutputStream: 在构造的时候,不用定义数据目的,因为该对象中已经内部封装了可变长度的自己数组,这就是数据目的地。

因为这两个流对象都操作数组,并没有使用系统资源,所以,不用进行close关闭。

源设备:

键盘 System.in 硬盘 FileStream 内存 ArrayStream

目的设备:

控制台 
System.out     硬盘 FileStream  内存 ArrayStream

用流的思想来操作数组

计算机只能识别二进制数据,早起又来是电信号

为了方便应用计算机,让它可以识别各个国家的文字,就将各个国家的文字用数字来表示

并一一对应,形成一张表

这就是编码表

ASCII: 美国标准信息交换码
用一个字节的7位可表示

ISO8859-1 :
拉丁码表,欧洲码表, 用一个字节的8位表示

GB2312:
中国的中文码表

GBK:
中国的中文编码表升级,融合了更多的中文文字字符号

Unicode:
国标标准码,融合了多种文字;

UTF-8:
最多用三个字节来表示一个字符

中间其实走过Unicode ,用你好来测试