偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Java文件I/O的三種方法

開(kāi)發(fā) 后端
RandomAccessFile是不屬于InputStream和OutputStream類系的。實(shí)際上,除了實(shí)現(xiàn)DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也實(shí)現(xiàn)了這兩個(gè)接口),它和這兩個(gè)類系毫不相干,甚至都沒(méi)有用InputStream和OutputStream已經(jīng)準(zhǔn)備好的功能;它是一個(gè)完全獨(dú)立的類,所有方法(絕大多數(shù)都只屬于它自己)都是從零開(kāi)始寫的。

[[173297]]

之前在面試中被問(wèn)到過(guò)兩次Java中文件讀入輸出怎么寫,當(dāng)時(shí)只記得一個(gè)大概,沒(méi)有辦法很清晰的說(shuō)出一個(gè)條理,今天特地看出總結(jié)了一下這方面的內(nèi)容,想要寫出來(lái)給大家分享。

首先文件讀入輸出流常用有三種:FileInputStream/FileOutputStream,F(xiàn)ileReader/FileWriter,RandomAccessFile。下面具體列出一些簡(jiǎn)單的例子參考:

基礎(chǔ)篇:

1.

  1. FileRead fr = new FileReader(filename);  
  2. String s;  
  3. while( (s=fr.readLine())!=null){  
  4. ...  
  5.  
  6. fr.close();  
  7. //FileWriter同理,輸出時(shí)可用write()函數(shù)  
  8. //Java I/O中所有的Reader、Writer都是面向字符流的輸出輸出 

2.

  1. FileInputStream fi =new FileInputStream(filename);  
  2. int in 
  3. while( (in=fi.read())!=-1){  
  4. ...  
  5.  
  6. fi.close();  
  7. //FileOutputStream同理  
  8. //Java I/O中所有的Reader、Writer都是面向字節(jié)流的輸出輸出 

3.

  1. RandomAccessFile ra =new RandomAccessFile(filename,"rw");//后面的參數(shù)指定的是  
  2. 打開(kāi)文件流的方式,“rw”是指讀寫,“r”是只讀,Java不提供只寫  
  3. ra.seek(number);//將文件指針移動(dòng)到number處,這里文件指針可以理解為文件開(kāi)始讀的位置  
  4. ra.skipByte(number);//跳過(guò)number個(gè)字節(jié)  
  5. ra.read();  
  6. ra.close();  
  7. //RandomAccessFile既可以讀也可以寫,而且可以利用seek()函數(shù)指定位置 

下面是百度百科的一些介紹:

RandomAccessFile是不屬于InputStream和OutputStream類系的。實(shí)際上,除了實(shí)現(xiàn)DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也實(shí)現(xiàn)了這兩個(gè)接口),它和這兩個(gè)類系毫不相干,甚至都沒(méi)有用InputStream和OutputStream已經(jīng)準(zhǔn)備好的功能;它是一個(gè)完全獨(dú)立的類,所有方法(絕大多數(shù)都只屬于它自己)都是從零開(kāi)始寫的。這可能是因?yàn)镽andomAccessFile能在文件里面前后移動(dòng),所以它的行為與其它的I/O類有些根本性的不同??偠灾且粋€(gè)直接繼承Object的,獨(dú)立的類。

進(jìn)階篇:

在nio中,Java重新實(shí)現(xiàn)了I/O流,并且引入了一些新的方法來(lái)提高速度。我主要介紹通道、內(nèi)存映射文件

1.通道:

通道和緩沖器是一個(gè)成對(duì)的概念,Thinking in Java中的一個(gè)例子特別好理解:我們把想要讀入的文件看作一個(gè)煤礦,數(shù)據(jù)就是我們想要的煤炭。通道好比是傳送煤礦的傳送帶,我們沒(méi)有辦法直接從傳送帶上拿走煤炭,只好利用卡車來(lái)裝載這些煤炭,卡車就是緩沖器,它主要負(fù)責(zé)從通道中取出數(shù)據(jù),傳給我們寫的程序。***能與通道交互的緩沖器是ByteBuffer??梢钥闯龊屯ǖ乐С值慕馕隽鞯姆绞绞亲止?jié)流。所以它配套使用的是FileInputStream/FileOutputStream,RandomAccessFile

例子:

a.

  1. FileChannel fc =new FileOutputStream(filename).getChannel();  
  2. fc.write(ByteBuffer.wrap("something test".getBytes() ));//這里使用ByteBuffer比較簡(jiǎn)單,其實(shí)ByteBuffer可以利用個(gè)put()函數(shù)寫入byte數(shù)組  
  3. fc.close(); 

b.

  1. fc= new FileOutputStream(filename).getChannel();  
  2. ByteBuffer buff = ByteBuffer.allocate(size);//沒(méi)錯(cuò),ByteBuffer是不提供顯示構(gòu)造函數(shù)的,想要新建一個(gè)對(duì)象必須利用allocate()函數(shù)來(lái)分配空間。  
  3. fc.read(buff);  
  4. fc.close(); 

為什么想到要用通道來(lái)做I/O呢?主要考慮的是性能問(wèn)題,通道加緩沖器能夠讓程序一些讀寫一定量的字符,而只使用InputStream/OutputStream,Reader/Writer只能一次讀寫一個(gè)字節(jié)/字符。而程序在進(jìn)行I/O時(shí)要交給操作系統(tǒng)去解決這部分功能(調(diào)用系統(tǒng)調(diào)用),減少交給操作系統(tǒng)的次數(shù)可以有效的消減I/O花費(fèi)的時(shí)間

2.內(nèi)存映射文件:

內(nèi)存映射文件主要的意思其實(shí)假定將文件都放入內(nèi)存中,把它當(dāng)作非常大的數(shù)組來(lái)訪問(wèn),效率特別好。為什么比較好呢?這要從Java虛擬機(jī)和操作系統(tǒng)開(kāi)始說(shuō)起le(其實(shí)我也不太懂,剛才看了一篇文章講的比較清晰,鏈接是http://www.360doc.com/content...)這篇文章主要介紹了Java I/O的原理以及內(nèi)存映射文件的原理。我嘗試概括一下:Java I/O主要的實(shí)現(xiàn)手段肯定是利用系統(tǒng)調(diào)用,而系統(tǒng)調(diào)用先將想要使用的文件從硬盤調(diào)入到內(nèi)核的I/O緩沖區(qū)中,這次會(huì)導(dǎo)入比Java程序想要的文件更多的內(nèi)容(拷入更多的內(nèi)容是因?yàn)槌绦虻木植啃栽?,能夠得到更好的效?,然后再?gòu)膬?nèi)核的I/O緩沖區(qū)導(dǎo)入到Java進(jìn)程自己的私有內(nèi)存空間中。而內(nèi)存映射文件放棄了兩次拷貝的方法,直接將Java進(jìn)程的虛擬空間與文件對(duì)象構(gòu)成一個(gè)映射,當(dāng)私有內(nèi)存空間中找不打想要的內(nèi)容時(shí)發(fā)生缺頁(yè)異常,然后利用更底層的系統(tǒng)調(diào)用解決這個(gè)問(wèn)題(其實(shí)在I/O的系統(tǒng)調(diào)用中也涉及到了缺頁(yè)異常處理),好處就是減少了一次從內(nèi)核I/O緩沖區(qū)到進(jìn)程私有地址的開(kāi)銷。

例子:

  1. FileChannel fc = new RandomAccessFile(filename,"rw").getChannel();  
  2. MappedByteBuffer mb = fc.map(FileChannel.MapMode.READ_WRITE,start,length);  
  3. mb.put((byte)'x');  
  4. mb.get();  
  5. fc.close(); 

寫到這里突然想到在《孔乙己》中“茴”的4中寫法,現(xiàn)在Java打開(kāi)文件也有了至少五種方法了,每一種都一各有利弊。以后也可以穿著長(zhǎng)袍問(wèn)別人你知道Java讀寫文件的5種方法么

責(zé)任編輯:武曉燕 來(lái)源: segmentfault
相關(guān)推薦

2009-07-08 12:56:32

編寫Servlet

2022-05-30 07:07:35

Java監(jiān)聽(tīng)文件Java 8

2021-12-20 07:11:26

Java List排序 Java 基礎(chǔ)

2022-05-31 16:00:46

Go 編程語(yǔ)言復(fù)制文件Go 標(biāo)準(zhǔn)庫(kù)

2010-09-14 15:10:49

CSS注釋

2022-07-13 16:06:16

Python參數(shù)代碼

2009-12-11 18:49:39

預(yù)算編制博科資訊

2023-08-14 17:58:13

RequestHTTP請(qǐng)求

2024-11-15 07:00:00

Python發(fā)送郵件

2011-04-18 15:32:45

游戲測(cè)試測(cè)試方法軟件測(cè)試

2011-06-10 10:43:12

Ubuntu應(yīng)用安裝

2009-06-23 10:45:18

Hibernate支持

2022-07-07 00:33:34

Java線程同步

2021-07-13 12:31:27

IT組織改進(jìn)首席技術(shù)官

2023-05-16 16:07:07

大數(shù)據(jù)數(shù)據(jù)管理工具

2009-07-23 15:17:54

JDBC連接Acces

2016-09-09 13:07:56

CentOSJDKLinux

2023-09-25 15:08:43

Python方離群值

2021-09-10 18:09:42

SQL注入漏洞網(wǎng)絡(luò)攻擊

2021-10-09 06:59:36

技術(shù)MyBatis數(shù)據(jù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)