日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

java面試題 --- IO

 貪挽懶月 2022-06-20 發(fā)布于廣東

1. IO流的分類有哪些?

  • 按照流向分為輸入流和輸出流;
  • 按照實現功能分為節(jié)點流和處理流。節(jié)點就是從一個特定的地方讀寫數據,包括數組操作,管道操作和文件操作;處理流對已存在的流進行封裝和處理,包括緩沖操作,打印操作和轉化操作等;
  • 按照處理數據的單位分為字節(jié)流和字符流

2. 為什么有字節(jié)流還要有字符流?

  • 字節(jié)流是 java 用來 ASCII 字符文件的,但 java 也支持其他字符,比如 unicode,為了方便操作字符且不會亂碼,就提供了字符流。

3. 什么是 java 序列化?

  • 將對象進行流化,對流化后的對象進行讀寫操作或者網絡傳輸。要序列化的對象必須實現 Serializable 接口。

4. 對象序列化的過程是什么?

  • 用輸出流構造一個 ObjectOutputStream 對象,然后調用其 writeObject(Object obj) 方法即可將對象轉化成流,反序列化就是用輸入流。

5. 如何克隆對象?

  • 重寫 Object 的 clone 方法;
  • 通過序列化和反序列化克隆。

6. BIO、NIO 和 AIO 有什么區(qū)別?

  • BIO 是同步阻塞 IO,并發(fā)性不好;
  • NIO 是同步非阻塞 IO,JDK1.4 開始引入,基于通道和緩沖區(qū)操作,實現了 IO 多路復用;
  • AIO 是異步非阻塞 IO,并發(fā)性很好,基于事件和回調機制,目前還未廣泛使用。

7. 說說你對 NIO 的認識?
NIO 的核心就是緩沖區(qū)(Buffer)、通道(Channel)和選擇器(Selector)。
(1). 緩沖區(qū)(Buffer)就是用來存儲數據的,八種基本類型只有 Boolean 類型沒有提供對應的緩沖區(qū)。

  • 核心屬性:capacity,緩沖區(qū)的容量;limit,界線,緩沖區(qū)可用區(qū)域和已用區(qū)域的分界線;position,當前的位置。
  • 核心方法:allocate,分配緩沖區(qū);put,往緩沖區(qū)寫數據;get,從緩沖區(qū)讀數據;

(2). 通道(Channel)就是源位置與目標位置之間打開的連接,數據傳輸的通路。

  • 核心實現類:FileChannel,操作文件的通道;DatagramChannel,通過 UDP 讀取網絡數據的通道;SocketChannel,通過 TCP 讀取網絡數據的通道;ServerSocketChannel,監(jiān)聽 TCP 連接的通道。
  • 核心方法:transferTo/transferFrom,通道間的數據傳輸;write,將緩沖區(qū)數據寫入通道;read,把通道數據讀取到緩沖區(qū)。

(3). 選擇器用于IO多路復用,將channel都注冊到選擇器上,它會監(jiān)聽哪些通道有事件發(fā)生,然后進行處理。


8. 知道零拷貝嗎?

  • 首先普通拷貝的過程是,源文件先經過 DMA 拷貝到內核 buffer,然后通過 CPU 拷貝到用戶 buffer,接著再通過 CPU 拷貝到 socket buffer,最后通過 DMA 拷貝到協議棧。這里經過了四次拷貝,并且伴隨著三次用戶態(tài)的轉換,用戶態(tài)轉為內核態(tài),再轉為用戶態(tài),最后又轉為內核態(tài)。
  • 零拷貝不是不拷貝,是可以不經過用戶 buffer,直接從內核 buffer 通過 CPU 拷貝到 socket buffer,且這里拷貝的內容非常少,只拷貝長度、偏移量等信息。通過 linux 的 sendFile 函數即可實現零拷貝。java NIO 中的 transferFrom/transferTo 方法就通過 sendFile 函數實現了零拷貝。

掃描二維碼

    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多