您好,登錄后才能下訂單哦!
java io的重要性?這個問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
Java的IO流是實現(xiàn)輸入/輸出的基礎(chǔ),它可以方便地實現(xiàn)數(shù)據(jù)的輸入/輸出操作,在Java中把不同的輸入/輸出源抽象表述為"流"。
流是一組有順序的字節(jié)集合,是對數(shù)據(jù)傳輸?shù)目偡Q或抽象。
流有輸入和輸出,輸入時是流從數(shù)據(jù)源流向程序。輸出時是流從程序傳向數(shù)據(jù)源,而數(shù)據(jù)源可以是內(nèi)存,文件,網(wǎng)絡(luò)或程序等。
用戶進程和操作系統(tǒng)內(nèi)核
Java 中的IO可以理解為是在Java程序和操作系統(tǒng)內(nèi)核兩個對象之間進行的。
后面所說的阻塞和非阻塞,同步和異步都是這兩個對象相互作用的結(jié)果。在本文中,用戶進程指的就是Java程序。
程序空間和內(nèi)核空間
Waiting for the data to be ready(等待數(shù)據(jù)到達內(nèi)核緩沖區(qū))
Copying the data from the kernel to the process(從內(nèi)核緩沖區(qū)拷貝數(shù)據(jù)到程序緩沖區(qū))
在Linux中,對于一次讀取IO的操作,數(shù)據(jù)并不會直接拷貝到程序的程序緩沖區(qū)。
它首先會被拷貝到操作系統(tǒng)內(nèi)核的緩沖區(qū)中,然后才會從操作系統(tǒng)內(nèi)核的緩沖區(qū)拷貝到應(yīng)用程序的緩沖區(qū)。
程序空間:分配給用戶程序的內(nèi)存空間。
內(nèi)核空間:內(nèi)核擁有的內(nèi)存空間。
阻塞和非阻塞
阻塞:用戶進程進行系統(tǒng)調(diào)用后,用戶進程一直處于鎖定的狀態(tài),不能進行其他操作
非阻塞:用戶進程進行系統(tǒng)調(diào)用后,用戶進程沒有被鎖定,可以進行其他操作
阻塞和非阻塞說的是用戶進程的狀態(tài),即用戶進程是否被鎖定
同步和異步
A synchronous I/O operation causes the requesting process to be blocked until that I/O operation completes.
An asynchronous I/O operation does not cause the requesting process to be blocked.
一個同步的io操作會導(dǎo)致發(fā)起請求的進程阻塞直到這個io操作完成。一個異步的io操作不會導(dǎo)致請求的線程被阻塞。
同步:用戶線程和io線程做同一件事(用戶線程被阻塞,等待內(nèi)核返回處理結(jié)果)
異步:用戶線程和io線程做不同的事情(用戶線程不被阻塞,做其他的事情,內(nèi)核處理完成發(fā)送結(jié)果給用戶線程)
文件描述符
在Linux下面一切皆文件。文件描述符(file descriptor)是內(nèi)核為文件所創(chuàng)建的索引,所有I/O操作都通過調(diào)用文件描述符(索引)來執(zhí)行,包括下面我們要提到的socket。Linux剛啟動的時候會自動設(shè)置0是標準輸入,1是標準輸出,2是標準錯誤。
感謝各位的閱讀!看完上述內(nèi)容,你們對java io的重要性大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。