1. Java中的IO流分为几种?
IO流可以分为字节输入流,字节输出流,对应抽象类是InputSteam、OutputStream, 字符输入流,字符输出流,对应抽象类是Reader、Writer 访问文件:FileInputStream、 缓冲流:BufferedInputStream、 对象流 ObjectInputStream
2. 怎么打开一个大文件
打开大文件,应该避免直接把文件全部读取存到内存中,可以才有分次读取的方式。
- 使用缓存流。缓冲流内部维护一个缓存区,通过与缓冲区的交互,减少与设备的交互次数。使用缓冲输入流的时候,它会每次读取一批数据把缓冲区填满,每次调用读取方法并不是直接从设备取值,而是冲缓冲区取值,缓冲区为空了 就再一次读取数据把缓冲区填满
- 使用NIO。 NIO采用了内存映射文件的方式来处理输入/输出, NIO将文件活文件上的一段区域映射到内存中,这样就可以像访问内存一样来访问文件了。这种方式模拟了操作系统上的虚拟内存的概念。
3. BIO、NIO区别
BIO ,Blocking I/O, 同步阻塞式IO,也就是传统IO。特点是模式简单使用方便,并发处理能力低。数据的读取写入必须阻塞在一个线程内等待其完成。不适合高并发的系统
NIO: Non-blocking I/O: 同步非阻塞IO, 是传统IO升级。客户端和服务端通过Channel通讯,实现了多路复用。Java1.4引入java.nio包, 有Channel、Buffer、Selector三部分组成。数据可以从Channel读到Buffer中,也可以从Buffer写到Channel中。Buffer本质上是一块可以写入数据,然后可以从中读取数据的内存。Selector允许单线程处理多个 Channel,如果你的应用打开了多个连接(通道),但每个连接的流量都很低,使用Selector就会很方便。要使用Selector,得向Selector注册Channel,然后调用它的select() 方法。
4. 什么是对象的序列化机制
对象的序列化机制就是把内存中的Java对象转化成和平台无关的二进制流,从而允许把这个二进制流持久的保存在磁盘上,或者通过网络把这种二进制流传输到另一个网络节点。当其他程序获取了这种二进制流,就可以通过反序列化机制恢复成原来的Java对象。
5.Serializable接口为什么需要定义serialVersionUID变量?
serialVersionUID代表序列化的版本,通过定义类的序列化版本,在反序列化时,只要对象中所存的版本和当前类的版本一致,就允许做恢复数据的操作,否则将会抛出InvalidClassException序列化版本不一致的错误。 假如没有指定 serialVersionUID, Java 序列化过程中也会根据 class 文件自动生成一个 serialVersionUID 作为该类序列化版本 ID 号, 而如果类发生改动, 那么序列化机会会重新生成一个 serialVersionUID,对类的敏感性较高,可能会出现意外的InvalidClassException,所以最好显式的定义serialVersionUID
6.除了Java自带的序列号之外,你还了解哪些序列化工具?
JSON: 目前使用比较频繁的格式化数据工具,简单直观可读性好。有Jackson、gson、fastjson等
7 如果不用JSON工具,该如何实现对实体类的序列化?
可以使用Java原生的序列化机制,但是效率比较低一些,适合小项目; 可以使用其他的一些第三方类库,比如Thrift, 是轻量级RPC服务框架
|