什么是阻塞和非阻塞?我們就用管道的讀寫來舉例子。
如果沒聽過管道,就把他理解成文件就行。
一個程序打開管道,并且往管道里面寫入數據;
intmain() { intfd=open("fifo",O_WRONLY); if (-1 == fd) { perror("open"); } char buf[32] = {0}; scanf("%s", buf); if (write(fd, buf, strlen(buf)) == -1) { perror("write"); } return 0; }另一個程序打開管道,從管道里面讀取數據。
int main() { intfd=open("fifo",O_RDONLY); if (-1 == fd) { perror("open"); } charbuf[32]={0}; if (read(fd, buf, sizeof(buf)) == -1) { perror("write"); } return 0; }默認情況下,用open打開管道是阻塞的模式,也就是說,如果管道沒有數據,程序一直停在 read 函數這里,直到管道里面有數據,把它讀出來。
創建一個管道,運行程序,現象就是這樣的,程序此時阻塞在 read 函數。
如果通過寫進程往管道里面寫入數據,read能立馬把數據讀出來。
open函數還給我們提供了非阻塞的模式,加上這個選項,運行程序的時候,即使管道里面沒有數據,程序也不會停在 read 函數上,繼續向下執行。
這兩個現象,就是阻塞和非阻塞。
最后,放上百科的一段解釋,大家還有什么見解,歡迎在評論區交流。
阻塞和非阻塞指的是調用者(程序)在等待返回結果(或輸入)時的狀態。 阻塞時,在調用結果返回前,當前線程會被掛起,并在得到結果之后返回。 非阻塞時,如果不能立刻得到結果,則該調用者不會阻塞當前線程。 因此對應非阻塞的情況,調用者需要定時輪詢查看處理狀態。
審核編輯:劉清
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
阻塞
+關注
關注
0文章
24瀏覽量
8140
原文標題:什么是阻塞和非阻塞
文章出處:【微信號:學益得智能硬件,微信公眾號:學益得智能硬件】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
Verilog語言中阻塞和非阻塞賦值的不同
來源:《Verilog數字系統設計(夏宇聞)》 阻塞和非阻塞賦值的語言結構是Verilog 語言中最難理解概念之一。甚至有些很有經驗的Verilog 設計工程師也不能完全正確地理解:何時使用非
Verilog阻塞和非阻塞原理分析
Verilog阻塞和非阻塞原理分析在Verilog語言最難弄明白的結構中“非阻塞賦值”要算一個。甚至是一些很有經驗的工程師也不完全明白“
發表于 11-23 12:02
【分享】Verilog中阻塞與非阻塞語句
同了在第一個clk上升沿到來時,由于b的值未知,賦給c之后,c也為未知值;緊接著,把a的值給b,由于a的值已經給出,所以,結束之后,a、b的值相同,c為x。綜合之后,生成兩級移位寄存器。 關于非阻塞
發表于 11-03 20:26
深入分析verilog阻塞和非阻塞賦值
學verilog 一個月了,在開發板上面寫了很多代碼,但是始終對一些問題理解的不夠透徹,這里我們來寫幾個例子仿真出阻塞和非阻塞的區別
發表于 02-11 03:23
?1433次閱讀
從I/O的阻塞與非阻塞、I/O處理的單線程與多線程角度探討服務器模型
這里探討的服務器模型主要指的是服務器端對I/O的處理模型。從不同維度可以有不同的分類,這里從I/O的阻塞與非阻塞、I/O處理的單線程與多線程角度探討服務器模型。
FPGA的視頻教程之Verilog中阻塞與非阻塞的詳細資料說明
本文檔的主要內容詳細介紹的是FPGA的視頻教程之Verilog中阻塞與非阻塞的詳細資料說明。
發表于 03-26 17:16
?2次下載
阻塞與非阻塞通信的區別 阻塞和非阻塞應用場景
阻塞通信(Blocking Communication):當進行阻塞通信時,調用者在發起一個I/O操作后會被阻塞,直到該操作完成返回才能繼續執行后續代碼。
socket編程中的阻塞與非阻塞
在網絡編程中, socket 是一個非常重要的概念,它提供了一個抽象層,使得開發者可以不必關心底層的網絡通信細節。 socket 編程中的阻塞與非阻塞模式是兩種不同的操作方式,它們對程序的響應性
評論