• 【Java八股40天-Day5】 IO 和 NIO


    1. Java中的IO流分为几种?

    在这里插入图片描述
    IO流可以分为字节输入流,字节输出流,对应抽象类是InputSteam、OutputStream, 字符输入流,字符输出流,对应抽象类是Reader、Writer
    访问文件:FileInputStream、
    缓冲流:BufferedInputStream、 对象流 ObjectInputStream

    2. 怎么打开一个大文件

    打开大文件,应该避免直接把文件全部读取存到内存中,可以才有分次读取的方式。

    1. 使用缓存流。缓冲流内部维护一个缓存区,通过与缓冲区的交互,减少与设备的交互次数。使用缓冲输入流的时候,它会每次读取一批数据把缓冲区填满,每次调用读取方法并不是直接从设备取值,而是冲缓冲区取值,缓冲区为空了 就再一次读取数据把缓冲区填满
    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服务框架

  • 相关阅读:
    部署MES系统的实际作用和意义是什么?这篇文章总结得很全面
    一个完整的springboot项目所需要导入的依赖合集(方便查找)
    MATLAB中d2d函数用法
    ChatGPT原理简介
    【数据库04】中级开发需要掌握哪些SQL进阶玩法
    经典面试题 之 JVM调优
    方形平板振动克拉尼图形可视化计算MATLAB程序(Chladni Patterns)
    简历(快速上手)
    碎片笔记|AIGC核心技术综述
    数仓开发之DWS层(二)
  • 原文地址:https://blog.csdn.net/weixin_44179010/article/details/125445726