@muyanfeixiang
2014-11-24T22:28:23.000000Z
字数 3062
阅读 1539
Java
IO
1.编码问题
1.1中文机器上创建的文件只能识别ansi编码
1.2 utf-8编码汉字占3个字节,英文字符占1个字节
1.3 gbk编码 汉字占2个字节,英文占1个字节
1.4 utf-16be编码是java中的编码,汉字和英文都占两个自己
1.5. .getBytes() 将字符串编程byte类型
1.6. integer.toHexString() 将字节流编程16进制的int类型
1.7 用什么样的编码将字符串变成字节流,就要对应的解码方式
1.8 new String(byte[],"utf-8") 可以指定编码方式,默认是项目工程中的默认编码
1.9 byte[] bytes = new String("a").getBytes() 获取字符a的字节编码,默认编码
方式,可以制定getBytes("utf-8")等
2.0 new String(bytes,"utf-8")由字节构造字符串,如果不指定编码方式,就用默认的
2.java.io.File is used to get the information of the file,such as size,path,the parent directory. It can
not get the content of a file,but it can create a directory or a file and delete.
2.1 File.separator is the separator in the path, such '\' in Windows.
3.RandomAccessFile: java 提供的对文件内容的访问,既可以读文件,也可以写文件,支持随机访问
4.java文件模型:在硬盘上文件是以字节存储的,byte byte byte ...,是数据的集合
4.1 打开文件,"rw"读写打开,"r"只读打开
4.2 文件指针,在打开时都是在开头
4.3 写方法,raf.write(int)--->一个字节一个字节的写(后八位),同时指针指向下一个位置,准备下次写入
4.3 读方法, int b = raf.read()--->读一个字节
4.4 写入的都是字节流,所以本地打开的话,可能会因为编码问题出现乱码
5. IO流(输入流,输出流)字节流,字符流
6. 字节流
6.1 InputStream、OutputStream分别抽象了应用程序读取数据和写入数据的方式,都是抽象类
6.2 EOF =end 读到-1就读到结尾
6.3 输入流基本方法
int b = in.read();读入一个字节,无符号,填充int的低八位
in.read(byte[] buf) 读取数据填充到字符数组buf
in.read(byte[]buf,int start,int size) 读取数据到字节数组,从buf的start位置开始,长度为size
6.4 输出流 基本方法
out.write(int b) 写一个byte到流,b的低8位 //读一个3300kb的文件要10121ms
out.write(byte[] buf)
out.write(byte[] buf,int start,int size)//批量输出和批量输入效率高,是最常用的大文件读取方法,
以size20*1024,只要10ms
6.5 FileInputStream-->具体实现了在文件上读取数据,FileOutputStream继承了OutputStream
6.5.1 文件读入流
FileInputStream inputStream = new FileInputStream(src);
6.5.2文件写出流,
FileOutputStream fos = new FileOutputStream(file,true)
文件不存在,则创建,否则在后面追加内容
FileOutputStream fos = new FileOutputStream(file)
文件不存在,则创建,否则,删除后再创建
7.数据输入输出流,DataOutputStream和DataInputStream是对FileOutput/InputSream的扩展
可以更加方便的读取int,long,double,字符等类型数据
提供了诸如writeInt()/writeDouble/writeUTF(),是对普通写入流方法的包装
对应的是readInt,readLong等方法
DataInputStream dis = new DataInputStream(new FileInputStream())
8.8)BufferedInputStream;BufferedOutputStream
这两个流类位IO提供了带缓冲区的操作,一般打开文件进行写入,是对FileInputStream和FileOutputStream的包装
或读取操作时,都会加上缓冲,这种流模式提高了IO的性能
需要刷新缓冲区 是用flush
从应用程序中把输入放入文件,相当于将一缸水倒入到另一个缸中:
FileOutputStream--->;write()方法相当于一滴一滴地把水“转移”过去
9.字符流
java的文本(char)是16位无符号整数,是字符的unicode编码(双字节编码)
文件是byte byte byte ...的数据序列,文本文件是文本(char)序列按照某种
编码方案(utf-8,utf-16be,gbk)序列化为byte的存储结果
9.1字符流
Reader Writer)---->操作的是文本文本文件
字符的处理,一次处理一个字符
字符的底层任然是基本的字节序列
9.2字符流的基本实现
在相互转换的过程就需要指定编码类型
在相互转换的过程就需要指定编码类型
InputStreamReader 完成byte流解析为char流,按照编码解析
OutputStreamWriter 提供char流到byte流,按照编码处理
分别是对FileInputStream和FileOutputStream的包装
9.3FileReader/FileWriter
9.4字符流的过滤器
BufferedReader ---->readLine 一次读一行
BufferedWriter/PrintWriter ---->写一行
10. 对象的序列化,反序列化
10.1对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化
10.2序列化流(ObjectOutputStream),是过滤流----writeObject
10.3反序列化流(ObjectInputStream)---readObject
10.4序列化接口(Serializable)
对象必须实现序列化接口 ,才能进行序列化,否则将出现异常
这个接口,没有任何方法,只是一个标准
10.5transient关键字 表示某个属性不会被自动序列化,但是自己指定序列化的方式
private void writeObject(java.io.ObjectOutputStream s)
throws java.io.IOException
private void readObject(java.io.ObjectInputStream s)
throws java.io.IOException, ClassNotFoundException
分析ArrayList源码中序列化和反序列化的问题
10.6 序列化中 子类和父类构造函数的调用问题
父类继承了序列化接口,那么子类也都可以进行序列化,并且在序列化writeObject时会依次调用父类的构造函数
反序列化时,不会调用构造函数
对子类反序列化时,如果父类没有显示序列化接口,那么父类的构造函数就会被显式调用