帶緩沖讀寫(xiě)操作,“桶”的概念在哪體現(xiàn)?
//帶緩沖字節(jié)流讀取
?BufferedInputStream bis=new BufferedInputStream(new FileInputStream(srcFile));
??BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(destFile));
??int c;
??while((c=bis.read())!=-1){
???bos.write(c);
???bos.flush();
//不帶緩沖的字節(jié)流讀取
FileInputStream in=new FileInputStream(srcFile);
??FileOutputStream out=new FileOutputStream(destFile);
??int c;
??while((c=in.read())!=-1){
???out.write(c);
???out.flush();
??}
//具體讀寫(xiě)操作時(shí),read()方法返回的都是讀取到的字節(jié),write寫(xiě)入的也是讀到的字節(jié)內(nèi)容,為什么前者(帶緩沖)比(不帶緩沖)快?前者“桶”的概念在哪體現(xiàn)?盼快速回復(fù),謝謝!
2016-07-01
這個(gè)問(wèn)題首先要明白,讀取和寫(xiě)入的過(guò)程;
知道運(yùn)行內(nèi)存吧???計(jì)算機(jī)為什么要運(yùn)行內(nèi)存呢???其實(shí)運(yùn)行內(nèi)存就是一個(gè)緩沖區(qū)!!
文件的讀取和寫(xiě)入操作的過(guò)程是這樣的:
(1)首先說(shuō)一下批量讀取和單個(gè)字節(jié)的讀取
批量讀取是new一個(gè)對(duì)象,new一個(gè)對(duì)象就是在內(nèi)存中申請(qǐng)一個(gè)和new的要求的大小相一致的運(yùn)行內(nèi)存;
單個(gè)讀取系統(tǒng)默認(rèn)申請(qǐng)了一個(gè)字節(jié)的運(yùn)行內(nèi)存;
(2)文件的讀取和寫(xiě)入
?1.先說(shuō)單個(gè)字節(jié)的讀取,從原文件中讀取一個(gè)字節(jié)放入到內(nèi)存中,再?gòu)膬?nèi)存中把一個(gè)字節(jié)大小的數(shù)據(jù)放入到目標(biāo)文件中;(強(qiáng)調(diào)一次操作必須是直接從源文件到內(nèi)存再到目標(biāo)文件, 才能再次讀取下個(gè)字節(jié))
2.再說(shuō)批量讀取,同理
從原文件中讀取多個(gè)字節(jié)放入到內(nèi)存中,再?gòu)膬?nèi)存中把多個(gè)字節(jié)大小的數(shù)據(jù)放入到目標(biāo)文件中;(強(qiáng)調(diào)一次操作必須是直接從源文件到內(nèi)存再到目標(biāo)文件, 才能再次讀取下多字節(jié))
(3)從2中我們就能理解Buffer的運(yùn)行機(jī)制了,開(kāi)始解釋?zhuān)ㄔ購(gòu)?qiáng)調(diào)一下運(yùn)存既是緩存區(qū))
buffer的單個(gè)讀取,同理讀取既是先讀取一個(gè)字節(jié)放入內(nèi)存中,在讀取一個(gè)字節(jié)中,直到讀取完整個(gè)文件,批量從緩存中放到目標(biāo)文件中,可以看粗這樣節(jié)省了一次一次的從內(nèi)存中到目標(biāo)文件的過(guò)程即(1——》2——》3變成了1——》3,這樣從需要花費(fèi)2步,變成只花費(fèi)了一步,所以buffer的性能應(yīng)該是正常的一倍)
buffer的批量讀取,同理讀取既是先讀取多個(gè)字節(jié)放入內(nèi)存中,在讀取多個(gè)字節(jié)中,直到讀取完整個(gè)文件,批量從緩存中放到目標(biāo)文件中,可以看粗這樣節(jié)省了一次一次的從內(nèi)存中到目標(biāo)文件的過(guò)程即(1——》2——》3變成了1——》3,這樣從需要花費(fèi)2步,變成只花費(fèi)了一步,所以buffer的性能應(yīng)該是正常的一倍)
(4)總結(jié),累死我了,以上內(nèi)容純屬自己瞎想,沒(méi)有驗(yàn)證,求大神驗(yàn)證,告訴我答案,
? ? 我是渣渣,我是新手,驗(yàn)證發(fā)現(xiàn)我說(shuō)的錯(cuò)了,請(qǐng)不要罵我,xiexie
2015-07-08
比如說(shuō),
現(xiàn)在有一個(gè)水管,水流很慢,一滴一滴的流,然后你只能一滴一滴的喝。
不過(guò)呢你有了一個(gè)杯子(BuffederInputStream)你可以讓杯子一滴一滴的接著。
什么時(shí)候不需要水了,拿起來(lái)直接喝掉。這就是緩沖區(qū)
2015-07-08
你這個(gè)比喻不夠形象哦
2015-07-08
你這個(gè)沒(méi)有定義緩存size
要是想理解概念就好辦
100000個(gè)芝麻,從A碗到B碗問(wèn)題
沒(méi)buff邏輯:一個(gè)一個(gè)拿過(guò)去
buff邏輯:一把一把(10000個(gè))抓過(guò)去
(抓過(guò)去的路上浪費(fèi)了很多時(shí)間)
產(chǎn)生區(qū)別的原因其實(shí)很復(fù)雜。沒(méi)buff浪費(fèi)時(shí)間主要是IO操作次數(shù)太多(IO操作往往是效率瓶頸)
2015-07-07
懂了嗎????
2015-07-07
有圖有真相
2015-07-07
需要我的代碼嗎
2015-07-07
剛剛我自己實(shí)驗(yàn)了一番,用緩沖區(qū)復(fù)制相同文件用來(lái)195毫秒,不使用緩沖區(qū)用了400毫秒左右,因?yàn)椴环€(wěn)定,但是都在那個(gè)范圍之間。
2015-07-07
你可以這樣試試,寫(xiě)一個(gè)復(fù)制文件的代碼一個(gè)用緩沖區(qū)一個(gè)不使用緩沖區(qū),并在開(kāi)始復(fù)制是記錄時(shí)間,結(jié)束后記錄時(shí)間,看看那個(gè)快。如果不會(huì)使用java中獲取當(dāng)前時(shí)間的方法的話(huà),自己去找吧