NIO

主要是增加了通道FileChannel类,而且通道主要与缓冲器ByteBuffer进行结合处理。旧的IO修改了FileInputStream和FileOutputStream和RamdomAccessFile(字节流操作),还有设置字符的类Charset,还有ByteBuffer可以进行转换通过ascharBuffer、IntBuffer等。
用缓冲器操纵数据:Buffer有数据和可以高效地访问及操作这些数据的四个索引组成,这四个索引是mark、position、limit、capacity      编程思想里的一幅图561页

NIO一个重要的特性:内存映射文件,允许我们创建和修改那些因为太大而不能放入内存的文件。主要是通过MappedBufferReader类来完成操作,这个类继承bytebuffer类。
MapperedByteBuffer out = new RamdomAccessFile("test.dat","rw").getchannel().map(FileChannel.MapMode.READ_WRITE,0,length)   通过getchannel方法得到通道,再通过map方法得到MapperedByteBuffer类,还有必须指定映射文件的初始长度和映射区域长度。使用内存映射操作,效率是最高的。
对映射文件有锁机制,使用FileLock类,有三个方法tryLock(非阻塞),lock(阻塞),release(释放)。这个锁是文件通道上的锁。而且可以对文件的部分加锁,指定范围就好。

javaIO可以进行文件的压缩与解压。使用的类是ZipOutputStream(ZipInputStream)压缩成Zip格式和GZipOutputStream(GZipInputStream)压缩成GZip格式。同时配合两个类校验:CheckedInputStream和CheckedOutputStream
还有Zip文件应用与JAR文件格式。但是JAR没有那么强大。

java对象序列化:将那些实现Serializable接口的对象转化成一个序列字节,并且可以恢复成原来的对象,序列化能自动弥补不同操作系统之间的差异。它运用与语言主要为了支持两种机制:rmi和java beans      要序列化一个对象,先创建OutputStream对象,然后封装在ObjectOutputStream类中,然后通过方法writeObject方法写入硬盘。读的方式正好相反。
当然也可以ByteArrayOutputStream(ByteArrayInputStream)进行操作。

继承Serializable对象,但不想序列化某个属性,可以用transient关键字。
Externalizable和Serializable的区别,前者继承后者,但是有比较大的区别,前者的同时还添加了writeExternal()和readExternal()两个方法,这两个方法会在序列化和反序列化中自动被调用。其次他们的序列话机制有区别:前者它序列化和反序列化的时候会调用默认的构造器,并且在反序列话时readExternal方法没有对类的属性值赋值,那么他反序列化得到的值就为空(最重要的区别)。后者序列化机制:完全以它存诸的二进制为基础来构造,而不调用构造器。

除了使用java序列化之外,还可以用xml来存储和读取数据(可以用于任何平台和语言),可以使用开源的XOM类库来进行操作。
其次还可以用JDK自带的Preferences API 进行持久化操作,他可以自动的存储和读取信息。但是他的操作有限制:只能用于存储不超过8k的数据,也就是存储基本类型和字符串的操作

你可能感兴趣的:(nio)