淺析Java IO相關(guān)知識點
最近面試問的比較多的問題就是IO這一塊了,有些也答出來了,有些答的不好,最近這段時間開始深入了解一些這方面的東西,也想總結(jié)一下。
前置點
1,用戶空間系統(tǒng)空間
Linux系統(tǒng)會把一個進程分為兩個空間,用戶空間和系統(tǒng)空間,比如我們正常的編碼,操作的都是用戶空間的,那如果我們需要調(diào)用系統(tǒng)功能,比如拷貝系統(tǒng)文件,這種就需要調(diào)用系統(tǒng)組件,獲取內(nèi)核服務(wù),完成操作
IO的兩個階段
IO的執(zhí)行過程中分為兩個階段,等待就緒,執(zhí)行拷貝
等待就緒:我們知道,我們執(zhí)行IO操作的時候,數(shù)據(jù)可能來自別的應(yīng)用程序或者網(wǎng)絡(luò),如果沒有數(shù)據(jù),操作系統(tǒng)是會一直等待的,此時,應(yīng)用程序可能也會一直等待
執(zhí)行拷貝:將數(shù)據(jù)拷貝到應(yīng)用程序工作區(qū)
阻塞與非阻塞,同步與異步
先說同步與非同步,最簡單就是看是否啟動一個線程或者進程來完成IO這件事情,同步IO的時候,系統(tǒng)會停下來等這個做完才能做別的事情,而異步IO就利用多線程的方式,啟動一個新的線程去做這件事情,而自己就可以去干別的事情等待通知
再說阻塞與非阻塞吧,這兩個其實關(guān)注的是程序在等待調(diào)用結(jié)果的時候的狀態(tài),阻塞是指,你在獲取這個結(jié)果的時候,你會一直掛起,直到等到完整結(jié)果之后你才會繼續(xù)執(zhí)行,非阻塞是指,在該進程不能獲取結(jié)果的時候,沒有阻塞線程,這個有點繞,有一個通俗的解釋,如果是阻塞的,我要獲取這個東西,獲取過程中,我就失去了CPU,等到結(jié)果之后我才會獲取CPU,但是如果我是非阻塞,我就繼續(xù)持有CPU,我還可以一直檢查
幾種IO模型
目前比較多的就是5種
阻塞IO
最傳統(tǒng)的一種IO,即讀寫會發(fā)生阻塞現(xiàn)象的
非阻塞IO
用戶發(fā)起read的時候,并不會失去CPU,會一直check,如果沒有成功,會返回一個error,如果收到成功信號,就會發(fā)起read操作,獲取完整結(jié)果
多路復(fù)用IO
這個就是Java NIO的核心了,會有一個線程管理多個socket的狀態(tài),檢查是否有準備好的,只有發(fā)現(xiàn)真正準備好,才會調(diào)用cpu執(zhí)行IO操作,這塊是比較重要的
信號驅(qū)動IO
用的少,忽略
異步IO
起一個線程去執(zhí)行吧
相關(guān)文章
Java?synchronized輕量級鎖實現(xiàn)過程淺析
這篇文章主要介紹了Java synchronized輕量級鎖實現(xiàn)過程,synchronized是Java里的一個關(guān)鍵字,起到的一個效果是"監(jiān)視器鎖",它的功能就是保證操作的原子性,同時禁止指令重排序和保證內(nèi)存的可見性2023-02-02
Java及Android中常用鏈式調(diào)用寫法簡單示例
這篇文章主要介紹了Java及Android中常用鏈式調(diào)用寫法,結(jié)合實例形式分析了java編程中的鏈式調(diào)用概念、簡單使用方法及相關(guān)操作技巧,需要的朋友可以參考下2018-01-01
Netty中的DelimiterBasedFrameDecoder使用方法詳解
這篇文章主要介紹了Netty中的DelimiterBasedFrameDecoder使用方法詳解,DelimiterBasedFrameDecoder與LineBasedFrameDecoder類似,只不過更加通用,允許我們指定任意特殊字符作為分隔符,我們還可以同時指定多個分隔符,需要的朋友可以參考下2023-12-12
詳解Spring Cloud Gateway基于服務(wù)發(fā)現(xiàn)的默認路由規(guī)則
這篇文章主要介紹了詳解Spring Cloud Gateway基于服務(wù)發(fā)現(xiàn)的默認路由規(guī)則,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05

