Java加速讀取復制超大文件
用文件通道(FileChannel)來實現(xiàn)文件復制,供大家參考,具體內(nèi)容如下
不考慮多線程優(yōu)化,單線程文件復制最快的方法是(文件越大該方法越有優(yōu)勢,一般比常用方法快30+%):
直接上代碼:
package test; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.nio.channels.FileChannel; public class Test { public static void main(String[] args) { File source = new File("E:\\tools\\fmw_12.1.3.0.0_wls.jar"); File target = new File("E:\\tools\\fmw_12.1.3.0.0_wls-copy.jar"); long start, end; start = System.currentTimeMillis(); fileChannelCopy(source, target); end = System.currentTimeMillis(); System.out.println("文件通道用時:" + (end - start) + "毫秒"); start = System.currentTimeMillis(); copy(source, target); end = System.currentTimeMillis(); System.out.println("普通緩沖用時:" + (end - start) + "毫秒"); } /** * 使用文件通道的方式復制文件 * @param source 源文件 * @param target 目標文件 */ public static void fileChannelCopy(File source, File target) { FileInputStream in = null; FileOutputStream out = null; FileChannel inChannel = null; FileChannel outChannel = null; try { in = new FileInputStream(source); out = new FileOutputStream(target); inChannel = in.getChannel();//得到對應的文件通道 outChannel = out.getChannel();//得到對應的文件通道 inChannel.transferTo(0, inChannel.size(), outChannel);//連接兩個通道,并且從inChannel通道讀取,然后寫入outChannel通道 } catch (IOException e) { e.printStackTrace(); } finally { try { in.close(); inChannel.close(); out.close(); outChannel.close(); } catch (IOException e) { e.printStackTrace(); } } } /** * 普通緩沖復制 * @param source 源文件 * @param target 目標文件 */ public static void copy (File source, File target) { InputStream in = null; BufferedOutputStream out = null; try { in = new BufferedInputStream(new FileInputStream(source)); out = new BufferedOutputStream(new FileOutputStream(target)); byte[] buf = new byte[4096]; int i; while ((i = in.read(buf)) != -1) { out.write(buf, 0, i); } } catch (Exception e) { e.printStackTrace(); } finally { try { if (null != in) { in.close(); } if (null != out) { out.close(); } } catch (IOException e) { e.printStackTrace(); } } } } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
springboot集成Swagger的方法(讓你擁有屬于自己的api管理器)
在大型的項目中,如果你有非常多的接口需要統(tǒng)一管理,或者需要進行接口測試,那么我們通常會在繁雜地api中找到需要進行測試或者管理的接口,接下來通過本文給大家介紹springboot集成Swagger的方法讓你擁有屬于自己的api管理器,感興趣的朋友一起看看吧2021-11-11springcloud本地調(diào)試feign調(diào)用出現(xiàn)的詭異404問題及解決
這篇文章主要介紹了springcloud本地調(diào)試feign調(diào)用出現(xiàn)的詭異404問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03SpringBoot @ConfigurationProperties使用詳解
這篇文章主要介紹了SpringBoot @ConfigurationProperties使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02Java并發(fā)系列之CyclicBarrier源碼分析
這篇文章主要為大家詳細分析了Java并發(fā)系列之CyclicBarrier源碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03解決mybatis一對多查詢resultMap只返回了一條記錄問題
小編接到領(lǐng)導一個任務需求,需要用到使用resultMap相關(guān)知識,在這小編記錄下這個問題的解決方法,對mybatis一對多查詢resultMap項目知識感興趣的朋友一起看看吧2021-11-11深入講解java線程與synchronized關(guān)鍵字
Java 中多線程的同步依靠的是對象鎖機制,synchronized關(guān)鍵字就是利用了封裝對象鎖來實現(xiàn)對共享資源的互斥訪問。下面這篇文章主要介紹了java線程與synchronized關(guān)鍵字的相關(guān)資料,需要的朋友可以參考下。2017-03-03Mybatis中的mapper是如何和XMl關(guān)聯(lián)起來的
這篇文章主要介紹了Mybatis中的mapper是如何和XMl關(guān)聯(lián)起來的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06