阻塞非阻塞和同步非同步的區分 參考一些書籍

来源:https://www.cnblogs.com/soker/archive/2022/07/03/16440265.html
-Advertisement-
Play Games

編程中一直對這兩個概念不是很理解,在網上搜了很多資料大概描述的其實都很模糊,有時候還自相矛盾,很容易搞混,這裡說一下我對這兩個概念的理解。 首先看一下相關技術書籍對這兩個概念的描述,下麵分別是摘自《深入理解Java核心技術》和《Java併發程式設計中的》的內容。 摘自《深入理解Java核心技術》14 ...


編程中一直對這兩個概念不是很理解,在網上搜了很多資料大概描述的其實都很模糊,有時候還自相矛盾,很容易搞混,這裡說一下我對這兩個概念的理解。
首先看一下相關技術書籍對這兩個概念的描述,下麵分別是摘自《深入理解Java核心技術》和《Java併發程式設計中的》的內容。
摘自《深入理解Java核心技術》14.2:

當I/O操作發生時,一定是有兩方參與的,分別是調用方和被調用方。阻塞和非阻塞描述的是調用方,同步和非同步描述的是被調用方。
例如A調用B:
1.如果是阻塞,那麼A在發出調用命令後,要一直等待B返回結果。
2.如果是非阻塞,那麼A在發出調用命令後,不需要等待,可以去做自己的事情。
3.如果是同步,那麼B在收到A的調用命令後,會立即執行要做的事,A的本次調用可以得到結果
4.如果是非同步,那麼B在收到A的調用命令後,不保證會立即執行要做的事,但是保證會做,B在做好了之後會通知A。A的本次調用得不到·結果,但是B執行完成要做的事之後會通知A。
因為同步/非同步與阻塞/非阻塞描述的對象不同,所以這二者之間是沒有必然聯繫的。也就是說,同步不一定阻塞,非同步也不一定非阻塞。
只不過通常很少存在非同步且阻塞的場景,所以很多人誤以為同步一定是非阻塞的、非同步一點事非阻塞的。

摘自《Java高併發程式設計》1.2:

同步和非同步通常用來形容一次方法的調用。同步方法調用一旦開始,調用者必須等到方法調用返回後,才能繼續後續的行為。非同步方法調用更像一個消息傳遞,一旦開始,方法調用就會立即返回,調用者就可以繼續後續的操作。而非同步方法通常會在另外一個線程中“真實”地執行。整個過程,不會阻礙調用者的工作。對於調用者來說,非同步調用似乎是一瞬間就完成的。如果非同步調用需要返回結果,那麼當這個非同步調用真實完成時,則會通知調用者。
阻塞和非阻塞通常用來形容多線程間的相互影響。比如一個線程占用了臨界區資源,那麼其他所有需要這個資源的線程就必須在這個臨界區中進行等待。等待會導致線程掛起,這種情況就是阻塞。此時,如果占用資源的線程一直不願意釋放資源,那麼其他所有阻塞在這個臨界區上的線程都不能工作。 非阻塞的意思與之相反,它強調沒有一個線程可以妨礙其他線程執行。所有的線程都會嘗試不斷前向執行。

兩本書籍的描述切入點不一樣,乍一看兩個書籍描述的可能還有點衝突,反而讓人更迷糊。
在我看來阻塞和非阻塞必然是線程或進程相關的,阻塞指的是如果線程無法立即完成任務是否會進入阻塞狀態,非阻塞則與之相反。
同步即所有的代碼都是按順序執行的,可以理解為這個事情不幹完了我就不幹別的事情。非同步則不可預測順序的,非同步調用必須伴隨著通知,可以理解為等到取值完成後我再進行後續的操作,我先去乾別的事情。

同步非同步和阻塞非阻塞搭配就會出現如下四種組合:

  1. 同步阻塞,如果不能立即獲取數據,則線程阻塞等待數據返回。因為程式阻塞了,需要有其他程式將程式喚醒(這裡很重要),如java類FileInputStream的readBytes操作。
  2. 同步非阻塞,如果不能立即獲取數據,則迴圈檢查數據是否完成。這裡不需要其他線程參與喚醒操作。比如java類AtomicInteger的自增操作,如果不能加1就迴圈執行。
  3. 非同步非阻塞,如果不能立即獲取數據,則立即返回執行其他操作。等到數據返回了,接收到通知後再進行後續的處理工作(這裡後續的處理操作是別的線程去做了,因為當前線程可能已經退出了)。
  4. 非同步阻塞,這應該是一個並不存在的組合,非同步和阻塞是互斥的。既然都可以非同步執行,你還阻塞乾什麼呢,執行完成之後再通知你不就好了嗎,非同步的目的不就是無法立即獲取數據讓線程去乾別的事情嗎,如果沒有別的事情可做就同步阻塞等待就可以了

總結:
如果一個程式說他是非同步的,那他肯定非阻塞的,因為並不存在非同步阻塞。開啟非同步的目的就是不想讓當前線程阻塞,讓他去乾其他事情。就是你需要獲取一個資源或發出一個通知,但是你並不能立即獲取這個資源或者知道通知是否發送成功,這個時候你就需要線程去乾別的事(這裡的別的事指不依賴前面調用返回結果的代碼)。等結果出來了再對結果進行處理,如對資源解析或者重新發送消息。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 微服務可以對你的企業產生積極的影響。因此,值得瞭解如何處理微服務架構(MSA)和一些微服務的設計模式,以及,微服務架構的一般目標或原則。以下是微服務架構方法中需要考慮的四個目標。 降低成本。MSA將降低設計、實施和維護IT服務的總體成本。 提高發佈速度:MSA將提高從想法到部署服務的速度。 提高複原 ...
  • springboot項目上傳存儲圖片到七牛雲伺服器 問題描述: 當圖片存在本地時會出現卡頓的現象。比如一篇圖文混排的文章,如果圖片沒有載入完,可能整個文章都顯示不出來,因為它們都是用的同一個伺服器。 但是如果把圖片單獨拿出來放在雲伺服器上進行載入,這樣圖片的載入和文字的載入互不幹擾,就可以優化這個問 ...
  • 促使我寫這篇文章主要是在寫一個關於虛擬貨幣賬戶監控的項目時使用 Ticker 的問題。 Ticker 的問題 如果用過 Ticker 的朋友會知道,創建 Ticker 後並不會馬上執行,而是會等待一個時間 d,這就是創建時的間隔時間。如果間隔時間很短這基本上不會有太大問題,但是如果對首次執行時間有要 ...
  • ​ 隨著互聯網的快速發展,各種組件層出不窮,需要框架集成的組件越來越多。每一種組件與Spring容器整合需要實現相關代碼。SpringMVC框架配置由於太過於繁瑣和依賴XML文件;為了方便快速集成第三方組件和減少對配置文件的依賴,SpringBoot應運而生,其中採用了約定大於配置的理論讓開發者不需 ...
  • 開發經常遇到分頁查詢的需求,但是當翻頁過多的時候,就會產生深分頁,導致查詢效率急劇下降。 有沒有什麼辦法,能解決深分頁的問題呢? 本文總結了三種優化方案,查詢效率直接提升10倍,一起學習一下。 ...
  • 背景介紹 在程式中,主線程啟動一個子線程進行非同步計算,主線程是不阻塞繼續執行的,這點看起來是非常自然的,都已經選擇啟動子線程去非同步執行了,主線程如果是阻塞的話,那還不如主線程自己去執行不就好了。那會不會有一種場景,非同步線程執行的結果主線程是需要使用的,或者說主線程先做一些工作,然後需要確認子線程執行 ...
  • 本文介紹了Netty對各種IO模型的支持以及如何輕鬆切換各種IO模型。還花了大量的篇幅介紹Netty服務端的核心引擎主從Reactor線程組的創建過程。在這個過程中,我們還提到了Netty對各種細節進行的優化,展現了Netty對性能極致的追求。 ...
  • 記憶體分析器 (MAT) 1. 記憶體分析器 (MAT) 1.1 MAT介紹 MAT是Memory Analyzer tool的縮寫。指分析工具。 1.2 MAT作用 Eclipse Memory Analyzer 是一種快速且功能豐富的Java 堆分析器,可幫助您發現記憶體泄漏並減少記憶體消耗。 使用記憶體 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...