首页 > 代码库 > IO流 总结三

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(intx),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 ,用你好来测试