java io的重要性?這個問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
創(chuàng)新互聯(lián)主營寶安網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,App定制開發(fā),寶安h5微信小程序定制開發(fā)搭建,寶安網(wǎng)站營銷推廣歡迎寶安等地區(qū)企業(yè)咨詢
Java的IO流是實(shí)現(xiàn)輸入/輸出的基礎(chǔ),它可以方便地實(shí)現(xiàn)數(shù)據(jù)的輸入/輸出操作,在Java中把不同的輸入/輸出源抽象表述為"流"。
流是一組有順序的字節(jié)集合,是對數(shù)據(jù)傳輸?shù)目偡Q或抽象。
流有輸入和輸出,輸入時是流從數(shù)據(jù)源流向程序。輸出時是流從程序傳向數(shù)據(jù)源,而數(shù)據(jù)源可以是內(nèi)存,文件,網(wǎng)絡(luò)或程序等。
用戶進(jìn)程和操作系統(tǒng)內(nèi)核
Java 中的IO可以理解為是在Java程序和操作系統(tǒng)內(nèi)核兩個對象之間進(jìn)行的。
后面所說的阻塞和非阻塞,同步和異步都是這兩個對象相互作用的結(jié)果。在本文中,用戶進(jìn)程指的就是Java程序。
程序空間和內(nèi)核空間
Waiting for the data to be ready(等待數(shù)據(jù)到達(dá)內(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)存空間。
阻塞和非阻塞
阻塞:用戶進(jìn)程進(jìn)行系統(tǒng)調(diào)用后,用戶進(jìn)程一直處于鎖定的狀態(tài),不能進(jìn)行其他操作
非阻塞:用戶進(jìn)程進(jìn)行系統(tǒng)調(diào)用后,用戶進(jìn)程沒有被鎖定,可以進(jìn)行其他操作
阻塞和非阻塞說的是用戶進(jìn)程的狀態(tài),即用戶進(jìn)程是否被鎖定
同步和異步
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ā)起請求的進(jìn)程阻塞直到這個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是標(biāo)準(zhǔn)輸入,1是標(biāo)準(zhǔn)輸出,2是標(biāo)準(zhǔn)錯誤。
感謝各位的閱讀!看完上述內(nèi)容,你們對java io的重要性大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。