## 大白話搞懂什么是同步/異步/阻塞/非阻塞
> 異步/同步(被調用者),阻塞/非阻塞(調用者)
https://mp.weixin.qq.com/s/TW82I31CVRbKOwJGnTTP8A
原創:wangzenghuang[深夜里的程序猿](javascript:void(0);)*4月17日*

####
#### **前言**
在最近的一些面試中,跟應聘者聊了比較多關于“同步/異步,阻塞/非阻塞”相關的話題,發現大家對于這些概念的理解都比較模糊,甚至有的同學會反問“他們不就是同一個東西嗎?”。所以借著這么一個機會,我想用一些盡量簡單的例子,盡量簡潔的語言來聊聊自己對于這些概念的看法。
#### **正文**
這篇文章想通過一個老王“候車”的案例來解釋這些概念。
##### **同步阻塞**
放假了,老王回到了鄉下,由于鄉下的基礎設施比較差,當他在車站候車的時候,只能一直在干等著,直到公交車的到站。
這時候對于公交車(被調用著者)來說,它是“同步“的。老王(調用者)被公交車(被調用者)“阻塞”在站臺上。
##### **異步阻塞**
放完假了,老王回到了大城市開始上班,同樣在車站候車,一樣在車站干等著,但是大城市的基礎設施建設得比較好,當公交車到站的時候,會有廣播提示提醒乘客。
那么這時候對于公交車(被調用著者)來說,它是“異步“的,到站后會通知調用者。但是此時老王(調用者)還是被公交車(被調用者)“阻塞”在站臺上。
#####
##### **同步非阻塞**
過年了,老王放假回來了鄉下,又要開始候車了,這時候他變聰明了,沒有一直在車站上干等著,而是去找隔壁的小花敘敘舊。但是又害怕車到站了自己會錯過,就只能隔一段時間過來看看車到了沒。
那么這時候對于公交車(被調用著者)來說,它是“同步“的。但是此時老王(調用者)可以在候車的時候去干其他的的事情,所以他是“非阻塞”的。
##### **異步非阻塞**
改革春風吹滿地,新農村建設正在火熱進行中,此時的鄉下,公交車里面也安裝了車輛到站的提醒廣播。現在老王在候車的時候,可以安心的跟小花敘舊了,當聽到自己需要乘坐的車輛到站廣播時,才過去車站上車。
這時候對于公交車(被調用著者)來說,它是“異步“的,到站后會廣播提醒,此時老王(調用者)可以在候車的時候去干其他的的事情,所以他是“非阻塞”的
##### **概念總結**
從上面的示例中,我們可以明白一件事情,同步異步,阻塞非阻塞他們針對的對象是不一樣的。對于調用者來說是阻塞跟非阻塞,被調用者是同步跟異步。
同步:A調用B,此時只有等B有結果了才返回。
異步:?A調用B,B立即返回,無須等待。當B處理完之后會通過通知或者回調函數的方式來告訴A結果。
阻塞:A調用B,A會被被掛起,一直在等待B的結果,什么事都不能干。
非阻塞:A調用B,自己用被掛起等待B的結果,可以去干其他的事情。
##### **Java中相關概念**
在Java中的IO模型有三種,分別是BIO(同步阻塞IO),NIO(同步非阻塞IO),AIO(異步非阻塞IO)。這時候我們會發現,異步阻塞的模型是不存在的。
NIO跟AIO的出現解決了很多在BIO使用過程遇到的難題,所以我們在選擇使用何種IO的時候需要根據業務場景來做決定,沒必要一味追求NIO跟AIO,不僅加大了編碼的難度也提高的出錯的概率,技術的出現是為了更好的解決問題。
#### **結語**
這篇文章主要是想通過大家熟悉的場景來描述這些概念的含義以及區別,如果想更深入的去鉆研的話,大家可以去查閱Linux?IO模型相關資料,Java的IO?API也是基于這些基礎模型來封裝的。?

推薦閱讀
《[Java異常處理最佳實踐及陷阱防范](http://mp.weixin.qq.com/s?__biz=MjM5MDA4MjQyNQ==&mid=2465729606&idx=1&sn=90a98fa09b27a8604d978d49cd8dfbe8&chksm=b146985086311146ae7397f6fad7d3491a7aca2351e07cf591b75e5300f95315ea1d6751061f&scene=21#wechat_redirect)》
《[論JVM爆炸的幾種姿勢及自救方法](http://mp.weixin.qq.com/s?__biz=MjM5MDA4MjQyNQ==&mid=2465729580&idx=1&sn=78380bb15e9933ccbd4d5c43cc181aa3&chksm=b146983a8631112c31387d170a7c3e9c88df1a32f212536c9ffd1b12fc1d61140900749b1ec9&scene=21#wechat_redirect)》
《[一文徹底搞懂面試中常問的各種“鎖”](http://mp.weixin.qq.com/s?__biz=MjM5MDA4MjQyNQ==&mid=2465729531&idx=1&sn=963212c99b3b5d5f559be70830cba18a&chksm=b1469fed863116fb2a92ff3c8bfd9d2e8b3c39e8d781366b0da94b2c07e2f741fed20a82d36f&scene=21#wechat_redirect)》
看完本文有收獲?請轉發分享給朋友吧
**關注「深夜里的程序猿」,分享最干的干貨**

- 開始
- 公益
- 更好的使用看云
- 推薦書單
- 優秀資源整理
- 技術文章寫作規范
- SublimeText - 編碼利器
- PSR-0/PSR-4命名標準
- php的多進程實驗分析
- 高級PHP
- 進程
- 信號
- 事件
- IO模型
- 同步、異步
- socket
- Swoole
- PHP擴展
- Composer
- easyswoole
- php多線程
- 守護程序
- 文件鎖
- s-socket
- aphp
- 隊列&并發
- 隊列
- 講個故事
- 如何最大效率的問題
- 訪問式的web服務(一)
- 訪問式的web服務(二)
- 請求
- 瀏覽器訪問阻塞問題
- Swoole
- 你必須理解的計算機核心概念 - 碼農翻身
- CPU阿甘 - 碼農翻身
- 異步通知,那我要怎么通知你啊?
- 實時操作系統
- 深入實時 Linux
- Redis 實現隊列
- redis與隊列
- 定時-時鐘-阻塞
- 計算機的生命
- 多進程/多線程
- 進程通信
- 拜占庭將軍問題深入探討
- JAVA CAS原理深度分析
- 隊列的思考
- 走進并發的世界
- 鎖
- 事務筆記
- 并發問題帶來的后果
- 為什么說樂觀鎖是安全的
- 內存鎖與內存事務 - 劉小兵2014
- 加鎖還是不加鎖,這是一個問題 - 碼農翻身
- 編程世界的那把鎖 - 碼農翻身
- 如何保證萬無一失
- 傳統事務與柔性事務
- 大白話搞懂什么是同步/異步/阻塞/非阻塞
- redis實現鎖
- 淺談mysql事務
- PHP異常
- php錯誤
- 文件加載
- 路由與偽靜態
- URL模式之分析
- 字符串處理
- 正則表達式
- 數組合并與+
- 文件上傳
- 常用驗證與過濾
- 記錄
- 趣圖
- foreach需要注意的問題
- Discuz!筆記
- 程序設計思維
- 抽象與具體
- 配置
- 關于如何學習的思考
- 編程思維
- 談編程
- 如何安全的修改對象
- 臨時
- 臨時筆記
- 透過問題看本質
- 程序后門
- 邊界檢查
- session
- 安全
- 王垠
- 第三方數據接口
- 驗證碼問題
- 還是少不了虛擬機
- 程序員如何談戀愛
- 程序員為什么要一直改BUG,為什么不能一次性把代碼寫好?
- 碎碎念
- 算法
- 實用代碼
- 相對私密與絕對私密
- 學習目標
- 隨記
- 編程小知識
- foo
- 落盤
- URL編碼的思考
- 字符編碼
- Elasticsearch
- TCP-IP協議
- 碎碎念2
- Grafana
- EFK、ELK
- RPC
- 依賴注入
- 科目一
- 開發筆記
- 經緯度格式轉換
- php時區問題
- 解決本地開發時調用遠程AIP跨域問題
- 后期靜態綁定
- 談tp的跳轉提示頁面
- 無限分類問題
- 生成微縮圖
- MVC名詞
- MVC架構
- 也許模塊不是唯一的答案
- 哈希算法
- 開發后臺
- 軟件設計架構
- mysql表字段設計
- 上傳表如何設計
- 二開心得
- awesomes-tables
- 安全的代碼部署
- 微信開發筆記
- 賬戶授權相關
- 小程序獲取是否關注其公眾號
- 支付相關
- 提交訂單
- 微信支付筆記
- 支付接口筆記
- 支付中心開發
- 下單與支付
- 支付流程設計
- 訂單與支付設計
- 敏感操作驗證
- 排序設計
- 代碼的運行環境
- 搜索關鍵字的顯示處理
- 接口異步更新ip信息
- 圖片處理
- 項目搭建
- 閱讀文檔的新方式
- mysql_insert_id并發問題思考
- 行鎖注意事項
- 細節注意
- 如何處理用戶的輸入
- 不可見的字符
- 抽獎
- 時間處理
- 應用開發實戰
- python 學習記錄
- Scrapy 教程
- Playwright 教程
- stealth.min.js
- Selenium 教程
- requests 教程
- pyautogui 教程
- Flask 教程
- PyInstaller 教程
- 蜘蛛
- python 文檔相似度驗證
- thinkphp5.0數據庫與模型的研究
- workerman進程管理
- workerman網絡分析
- java學習記錄
- docker
- 筆記
- kubernetes
- Kubernetes
- PaddlePaddle
- composer
- oneinstack
- 人工智能 AI
- 京東
- pc_detailpage_wareBusiness
- doc
- 電商網站設計
- iwebshop
- 商品規格分析
- 商品屬性分析
- tpshop
- 商品規格分析
- 商品屬性分析
- 電商表設計
- 設計記錄
- 優惠券
- 生成唯一訂單號
- 購物車技術
- 分類與類型
- 微信登錄與綁定
- 京東到家庫存系統架構設計
- crmeb
- 命名規范
- Nginx https配置
- 關于人工智能
- 從人的思考方式到二叉樹
- 架構
- 今日有感
- 文章保存
- 安全背后: 瀏覽器是如何校驗證書的
- 避不開的分布式事務
- devops自動化運維、部署、測試的最后一公里 —— ApiFox 云時代的接口管理工具
- 找到自己今生要做的事
- 自動化生活
- 開源與漿果
- Apifox: API 接口自動化測試指南