使用缓冲字节流:BufferedInputStream与BufferedOutputStream读写数据
生活随笔
收集整理的這篇文章主要介紹了
使用缓冲字节流:BufferedInputStream与BufferedOutputStream读写数据
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
功能邏輯:將一個(gè)視頻文件通過(guò)緩沖字節(jié)輸入流進(jìn)行讀取,然后再通過(guò)緩沖字節(jié)輸出流將其重新拷貝輸出。
public static void main(String[] args) {try {FileInputStream fis = new FileInputStream("Rick_and_Morty.mkv");//第二個(gè)參數(shù)指定了緩沖區(qū)的size,根據(jù)實(shí)際的執(zhí)行時(shí)間可以優(yōu)化這個(gè)數(shù)字。BufferedInputStream bis = new BufferedInputStream(fis,1000000);FileOutputStream fos = new FileOutputStream("Rck.mkv");BufferedOutputStream bos = new BufferedOutputStream(fos,1000000);//byte數(shù)組會(huì)先從緩沖區(qū)取得數(shù)據(jù),大型文件對(duì)應(yīng)的數(shù)據(jù)可以大一些,小文件對(duì)應(yīng)的數(shù)組可以小一些。byte[] input = new byte[1000000];int count = 0;long before = System.currentTimeMillis();//while循環(huán)讀取視頻文件,-1代表已經(jīng)將文件的字節(jié)流全部讀取了,!=-1則文件繼續(xù)讀取while (bis.read(input) != -1) {bos.write(input);count++;}//輸入流一組,輸出流一組,先打開的流后關(guān)閉bis.close();fis.close();bos.close();fos.close();long after = System.currentTimeMillis();System.out.println("讀取時(shí)間為:" + (after - before) + "ms");System.out.println("訪問(wèn)磁盤:" + count + "次");} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}此例簡(jiǎn)單的實(shí)現(xiàn)了一個(gè)視頻文件從輸入到輸出的過(guò)程,視頻文件大小為301,199,257 ?bytes,執(zhí)行結(jié)果如下: 讀取時(shí)間為:450ms 訪問(wèn)磁盤:302次
這是通過(guò)多次改變字節(jié)數(shù)組的大小和緩沖區(qū)初始大小得出的較優(yōu)結(jié)果,在實(shí)際應(yīng)用中,可以多次進(jìn)行嘗試。
而且在實(shí)際應(yīng)用中,帶緩沖的字節(jié)輸入輸出流性能要優(yōu)于不帶緩沖區(qū)的字節(jié)輸入輸出流。
總結(jié)
以上是生活随笔為你收集整理的使用缓冲字节流:BufferedInputStream与BufferedOutputStream读写数据的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: LeetCode算法入门- Roman
- 下一篇: Tomcat运行三种模式:http-bi