IO模式精講總結

一、IO模型概述

Java中的IO模型主要分為BIO(同步阻塞IO)、NIO(同步非阻塞IO)和AIO(異步非阻塞IO)三種。它們分別適用于不同的業務場景,理解其核心機制對高性能網絡編程至關重要。


二、BIO:同步阻塞IO

1. 核心機制

BIO基于“一連接一線程”模型,服務端通過ServerSocket監聽端口,客戶端通過Socket發起連接。當服務端調用accept()read()時,線程會阻塞直至數據就緒。

2. 代碼示例

服務端代碼片段

ServerSocket serverSocket = new ServerSocket(9999);
Socket socket = serverSocket.accept(); // 阻塞
InputStream is = socket.getInputStream();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
String msg = br.readLine(); // 阻塞直至數據到達

客戶端代碼片段

Socket socket = new Socket("127.0.0.1", 9999);
PrintStream ps = new PrintStream(socket.getOutputStream());
ps.println("Hello BIO!");
ps.flush();

3. 優缺點分析

  • 優點:編程簡單,適合低并發場景。
  • 缺點:線程資源消耗大,高并發時易導致線程棧溢出。

三、NIO:同步非阻塞IO

1. 核心組件

NIO的三大核心為通道(Channel)緩沖區(Buffer)選擇器(Selector)

  • Channel:雙向通信管道,替代BIO的單向流。
  • Buffer:數據存儲容器,支持高效讀寫。
  • Selector:多路復用器,單線程管理多個Channel的事件。

2. 工作機制

通過Selector.select()監聽事件,實現非阻塞IO。服務端僅需一個線程即可處理多個連接請求,顯著提升性能。

服務端代碼片段

ServerSocketChannel serverChannel = ServerSocketChannel.open();
serverChannel.configureBlocking(false);
serverChannel.bind(new InetSocketAddress(9090));
Selector selector = Selector.open();
serverChannel.register(selector, SelectionKey.OP_ACCEPT);while (true) {selector.select(); // 事件監聽Set<SelectionKey> keys = selector.selectedKeys();Iterator<SelectionKey> iter = keys.iterator();while (iter.hasNext()) {SelectionKey key = iter.next();if (key.isAcceptable()) {// 處理連接事件} else if (key.isReadable()) {// 處理讀事件}iter.remove();}
}

3. Buffer操作流程

  1. 寫入數據buffer.put(data)
  2. 切換為讀模式buffer.flip()
  3. 讀取數據buffer.get()
  4. 清空緩沖區buffer.clear()

示例

ByteBuffer buffer = ByteBuffer.allocate(1024);
buffer.put("Hello NIO".getBytes());
buffer.flip();
while (buffer.hasRemaining()) {System.out.print((char) buffer.get());
}

4. 適用場景

適用于高并發短連接場景(如聊天服務器)。


四、AIO:異步非阻塞IO

1. 核心機制

AIO基于操作系統級別的異步通知機制,IO操作由OS完成后回調通知應用,無需線程阻塞。核心類包括AsynchronousServerSocketChannelCompletionHandler

2. 代碼示例

AsynchronousServerSocketChannel server = AsynchronousServerSocketChannel.open();
server.bind(new InetSocketAddress(9090));
server.accept(null, new CompletionHandler<AsynchronousSocketChannel, Void>() {@Overridepublic void completed(AsynchronousSocketChannel client, Void attachment) {ByteBuffer buffer = ByteBuffer.allocate(1024);client.read(buffer, buffer, new CompletionHandler<Integer, ByteBuffer>() {@Overridepublic void completed(Integer result, ByteBuffer buf) {System.out.println("收到數據:" + new String(buf.array()));}});}
});

3. 適用場景

適合長連接、重操作場景(如文件服務器),但實際應用中因編程復雜度和兼容性問題,使用較少。


五、三種IO模型對比

特性BIONIOAIO
阻塞性同步阻塞同步非阻塞異步非阻塞
線程模型一連接一線程單線程多路復用回調通知機制
適用場景低并發、簡單業務高并發短連接(如IM系統)高并發長連接(如文件傳輸)
編程復雜度簡單復雜復雜
JDK支持JDK1.0JDK1.4JDK1.7

六、總結

  1. BIO:適合快速原型開發,但需避免用于高并發場景。
  2. NIO:Netty等框架的底層實現,推薦用于高性能服務器開發。
  3. AIO:在特定場景下性能優異,但需評估框架支持度。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901415.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901415.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901415.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用pybind11開發c++擴展模塊輸出到控制臺的中文信息顯示亂碼的問題

使用pybind11開發供Python項目使用的C++擴展模塊時,如果在擴展模塊的C++代碼中向控制臺輸出的信息中包含中文,python程序的控制臺很容易出現亂碼。以如下C++擴展框架代碼為例(這是對上一篇文章簡明使用pybind11開發pythonc+擴展模塊教程-CSDN博客中的C++擴展框架代碼進行少量…

通過jstack分析線程死鎖場景

死鎖的四個必要條件&#xff1a;互斥、持有并等待、不可搶占、循環等待。 死鎖場景是兩個線程各自持有某個鎖&#xff0c;并試圖獲取對方持有的鎖&#xff0c;導致互相等待。 創建死鎖示例代碼 package io.renren.controller;import org.springframework.web.bind.annotation…

PyTorch梯度:深度學習的引擎與實戰解析

一、梯度&#xff1a;深度學習中的指南針 1.1 什么是梯度&#xff1f; 梯度是函數在某一點變化率最大的方向及其大小&#xff0c;就像爬山時最陡峭的上坡方向。在深度學習中&#xff0c;梯度告訴我們如何調整神經網絡參數&#xff0c;使損失函數最小化。 1.2 梯度的重要性 …

【Python爬蟲】詳細入門指南

目錄 一、簡單介紹 二、詳細工作流程以及組成部分 三、 簡單案例實現 一、簡單介紹 在當今數字化信息飛速發展的時代&#xff0c;數據的獲取與分析變得愈發重要&#xff0c;而網絡爬蟲技術作為一種能夠從互聯網海量信息中自動抓取所需數據的有效手段&#xff0c;正逐漸走入…

Golang|Channel 相關用法理解

文章目錄 用 channel 作為并發小容器channel 的遍歷channel 導致的死鎖問題用 channel 傳遞信號用 channel 并行處理文件用channel 限制接口的并發請求量用 channel 限制協程的總數量 用 channel 作為并發小容器 注意這里的 ok 如果為 false&#xff0c;表示此時不僅channel為空…

Windows單機模擬MySQL主從復制

這里寫自定義目錄標題 下載MySQL ZIP壓縮包安裝主庫1、創建配置文件2、安裝服務3、初始化數據庫4、啟動服務5、配置主庫 安裝從庫1、配置ini文件2、安裝服務3、初始化數據庫4、啟動服務5、配置從庫6、驗證從庫狀態 操作主庫驗證 下載MySQL ZIP壓縮包 https://dev.mysql.com/do…

OSPF路由引入

一、基本概念與作用 1.OSPF路由引入指通過自治系統邊界路由器&#xff08;ASBR&#xff09;將外部路由&#xff08;如BGP、RIP、靜態路由或其他OSPF進程的路由&#xff09;注入當前OSPF域&#xff0c;實現跨協議或跨區域的網絡互通?。 其核心作用包括&#xff1a; ?擴展網…

弱口令爆破

1.簡單介紹 弱口令是指一些簡單易猜的密碼&#xff0c;可通過社工方式和一些爆破工具進行破解&#xff0c;以下介紹一款爆破工具的用法。burpsuite簡稱BP&#xff0c;一款可以利用字典破解賬戶密碼的工具。 2.部署網站 可以使用PHPstudy的Apache服務&#xff0c;也可以使用I…

Vue3+Vite前端項目部署后部分圖片資源無法獲取、動態路徑圖片資源報404錯誤的原因及解決方案

目錄 Vue3vite前端項目部署后部分圖片資源無法獲取、動態路徑圖片資源報404錯誤的原因及解決方案 一、情景介紹 1、問題出現的場景 2、無法加載的圖片寫法 二、反向代理原理簡介 三、造成該現象的原因 四、解決方案 1、放棄動態渲染 2、在頁面掛載的時候引入圖片資源 …

詳解如何從零用 Python復現類似 GPT-4o 的多模態模型

&#x1f9e0; 向所有學習者致敬&#xff01; “學習不是裝滿一桶水&#xff0c;而是點燃一把火。” —— 葉芝 我的博客主頁&#xff1a; https://lizheng.blog.csdn.net &#x1f310; 歡迎點擊加入AI人工智能社區&#xff01; &#x1f680; 讓我們一起努力&#xff0c;共創…

榕壹云無人共享系統:基于SpringBoot+MySQL+UniApp的物聯網共享解決方案

無人共享經濟下的技術革新 隨著無人值守經濟模式的快速發展&#xff0c;傳統共享設備面臨管理成本高、效率低下等問題。榕壹云無人共享系統依托SpringBootMySQLUniApp技術棧&#xff0c;結合物聯網與移動互聯網技術&#xff0c;為商家提供低成本、高可用的無人化運營解決方案。…

基于PHP的酒店網上訂房系統(源碼+lw+部署文檔+講解),源碼可白嫖!

摘要 酒店服務是旅游行業的一個重要組成部分&#xff0c;它的作用已經從過去的單一的住宿、結算帳務向全面、高水平的服務型酒店轉變。酒店的服務工作貫穿于整個酒店的市場營銷、預定、入住、退房、結賬等環節&#xff0c;酒店要提高整體工作水平&#xff0c;簡化工作程序&…

【Linux生成SSH秘鑰實現遠程連接】Linux生成SSH秘鑰對與修改服務配置文件實現無密碼遠程連接

文章目錄 前言1. Linux 生成SSH秘鑰對2. 修改SSH服務配置文件3. 客戶端秘鑰文件設置4. 本地SSH私鑰連接測試5. Linux安裝Cpolar工具6. 配置SSHTCP公網地址7. 遠程SSH私鑰連接測試8. 固定SSH公網地址9. 固定SSH地址測試 前言 在數字化江湖中&#xff0c;企業對各種技術的需求就…

# linux 設置寬容模式

linux 設置寬容模式 在Linux系統中&#xff0c;通常沒有直接稱為“寬容模式”的設置選項&#xff0c;但你可以通過幾種方式來模擬或調整系統行為&#xff0c;使其表現得更加“寬容”&#xff0c;特別是在處理錯誤、權限問題或其他潛在問題時。以下是一些常見的方法&#xff1a…

【C++】——lambda表達式

&#x1f31f; 前言:??C Lambda表達式,當函數開始"叛逆期"?? 你是否有過這樣的崩潰瞬間&#xff1f; 為了寫個??只用到一次??的排序規則&#xff0c;被迫定義了一個類在std::for_each里塞函數指針&#xff0c;代碼瞬間變成"古董級"寫法看著層的循環…

深入解析B站androidApp接口:從bilibili.api.ticket.v1.Ticket/GetTicket到SendMsg的技術分析

前言 最近一段時間&#xff0c;我對B站的App接口進行了深入分析&#xff0c;特別是關注了認證機制和私信功能的實現。通過逆向工程和網絡抓包&#xff0c;發現了B站移動端API的底層工作原理&#xff0c;包括設備標識生成機制、認證流程和消息傳輸協議。本文將分享這些研究成果…

從零開始學A2A一:A2A 協議概述與核心概念

A2A 協議概述與核心概念 學習目標 基礎理解 掌握A2A協議的基本概念和背景理解協議的設計原則和核心思想了解協議在AI領域的重要性 技術掌握 熟悉A2A協議的核心功能組件掌握能力發現和任務管理機制理解多模態交互和安全通信原則 實踐應用 能夠設計基于A2A的智能體系統掌握協議…

2025.04.10-拼多多春招筆試第三題

?? 點擊直達筆試專欄 ??《大廠筆試突圍》 ?? 春秋招筆試突圍在線OJ ?? 筆試突圍OJ 03. 數字重排最大化問題 問題描述 LYA是一位專業的數字設計師。她手中有兩個數字序列 s 1 s_1

蒼穹外賣day04

Spring Task實現定時處理訂單狀態 作用&#xff1a;不需要輸入提示信號&#xff0c;便可定時自動執行程序 使用步驟 1、啟動類上加上注解&#xff08;EnableScheduling&#xff09;開啟定時任務調度 2、專門創建一個包來管理執行定時任務的類&#xff0c;該類需要交給IOC容…

BFD:網絡鏈路檢測與聯動配置全攻略

目錄 BFD簡介 BFD會話建立方式和檢測機制 BFD會話建立過程 BFD工作流程 聯動功能 BFD與OSPF聯動配置需求 BFD與OSPF聯動配置實現 BFD與VRRP聯動配置需求 BFD與VRRP聯動配置實現 單臂回聲 BFD默認參數及調整方法 BFD簡介 一種全網統一、檢測迅速、監控網絡中鏈…