日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

nio java 内核拷贝_大文件拷贝,试试NIO的内存映射

發布時間:2024/10/8 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nio java 内核拷贝_大文件拷贝,试试NIO的内存映射 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近項目里有個需求需要實現文件拷貝,在java中文件拷貝流的讀寫,很容易就想到IO中的InputStream和OutputStream之類的,但是上網查了一下文件拷貝也是有很多種方法的,除了IO,還有NIO、Apache提供的工具類、JDK自帶的文件拷貝方法

IO拷貝

public class IOFileCopy {

private static final int BUFFER_SIZE = 1024;

public static void copyFile(String source, String target) {

long start = System.currentTimeMillis();

try(InputStream in = new FileInputStream(new File(source));

OutputStream out = new FileOutputStream(new File(target))) {

byte[] buffer = new byte[BUFFER_SIZE];

int len;

while ((len = in.read(buffer)) > 0) {

out.write(buffer, 0, len);

}

System.out.println(String.format("IO file copy cost %d msc", System.currentTimeMillis() - start));

} catch (Exception e) {

e.printStackTrace();

}

}

}

傳統IO中文件讀取過程可以分為以下幾步:

內核從磁盤讀取數據到緩沖區,這個過程由磁盤操作器通過DMA操作將數據從磁盤讀取到內核緩沖區,該過程不依賴CPU

用戶進程在將數據從內核緩沖區拷貝到用戶空間緩沖區

用戶進程從用戶空間緩沖區讀取數據

NIO拷貝

NIO進行文件拷貝有兩種實現方式,一是通過管道,而是通過文件內存內存映射

public class NIOFileCopy {

public static void copyFile(String source, String target) {

long start = System.currentTimeMillis();

try(FileChannel input = new FileInputStream(new File(source)).getChannel();

FileChannel output = new FileOutputStream(new File(target)).getChannel()) {

output.transferFrom(input, 0, input.size());

} catch (Exception e) {

e.printStackTrace();

}

System.out.println(String.format("NIO file copy cost %d msc", System.currentTimeMillis() - start));

}

}

文件內存映射:

把內核空間地址與用戶空間的虛擬地址映射到同一個物理地址,DMA 硬件可以填充對內核與用戶空間進程同時可見的緩沖區了。用戶進程直接從內存中讀取文件內容,應用只需要和內存打交道,不需要進行緩沖區來回拷貝,大大提高了IO拷貝的效率。加載內存映射文件所使用的內存在Java堆區之外

public class NIOFileCopy2 {

public static void copyFile(String source, String target) {

long start = System.currentTimeMillis();

try(FileInputStream fis = new FileInputStream(new File(source));

FileOutputStream fos = new FileOutputStream(new File(target))) {

FileChannel sourceChannel = fis.getChannel();

FileChannel targetChannel = fos.getChannel();

MappedByteBuffer mappedByteBuffer = sourceChannel.map(FileChannel.MapMode.READ_ONLY, 0, sourceChannel.size());

targetChannel.write(mappedByteBuffer);

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

System.out.println(String.format("NIO memory reflect file copy cost %d msc", System.currentTimeMillis() - start));

File targetFile = new File(target);

targetFile.delete();

}

}

NIO內存映射文件拷貝可以分為以下幾步

NIO的內存映射實際上就是少了一次從內核空間拷貝到用戶空間的過程,將對用戶緩沖區的讀改為從內存讀取

Files#copyFile方法

public class FilesCopy {

public static void copyFile(String source, String target) {

long start = System.currentTimeMillis();

try {

File sourceFile = new File(source);

File targetFile = new File(target);

Files.copy(sourceFile.toPath(), targetFile.toPath());

} catch (IOException e) {

e.printStackTrace();

}

System.out.println(String.format("FileCopy file copy cost %d msc", System.currentTimeMillis() - start));

}

}

FileUtils#copyFile方法

使用FileUtils之前需先引入依賴

依賴

commons-io

commons-io

2.4

FileUtils#copyFile封裝類:FileUtilsCopy.java

public class FileUtilsCopy {

public static void copyFile(String source, String target) {

long start = System.currentTimeMillis();

try {

FileUtils.copyFile(new File(source), new File(target));

} catch (IOException e) {

e.printStackTrace();

}

System.out.println(String.format("FileUtils file copy cost %d msc", System.currentTimeMillis() - start));

}

}

性能比較

既然有這么多種實現方法,肯定要從中選擇性能最佳的

測試環境:

windows 10

CPU 6核

JDK1.8

測試代碼:PerformTest.java

public class PerformTest {

private static final String source1 = "input/test1.txt";

private static final String source2 = "input/test2.txt";

private static final String source3 = "input/test3.txt";

private static final String source4 = "input/test4.txt";

private static final String target1 = "output/test1.txt";

private static final String target2 = "output/test2.txt";

private static final String target3 = "output/test3.txt";

private static final String target4 = "output/test4.txt";

public static void main(String[] args) {

IOFileCopy.copyFile(source1, target1);

NIOFileCopy.copyFile(source2, target2);

FilesCopy.copyFile(source3, target3);

FileUtilsCopy.copyFile(source4, target4);

}

}

總共執行了五次,讀寫的文件大小分別為9KB、23KB、239KB、1.77MB、12.7MB

注意:單位均為毫秒

從執行結果來看:

文件很小時 => IO > NIO【內存映射】> NIO【管道】 > Files#copy > FileUtils#copyFile

在文件較小時 => NIO【內存映射】> IO > NIO【管道】 > Files#copy > FileUtils#copyFile

在文件較大時 => NIO【內存映射】> > NIO【管道】> IO > Files#copy > FileUtils#copyFile

修改IO緩沖區大小對拷貝效率有影響,但是并不是越大性能越好,稍大于拷貝文件大小即可

文件較小時,IO效率高于NIO,NIO底層實現較為復雜,NIO的優勢不明顯。同時NIO內存映射初始化耗時,所以在文件較小時和IO復制相比沒有優勢

如果追求效率可以選擇NIO的內存映射去實現文件拷貝,但是對于大文件使用內存映射拷貝要格外關注系統內存的使用率。推薦:大文件拷貝使用內存映射,原文是這樣的:

For most operating systems, mapping a file into memory is more

expensive than reading or writing a few tens of kilobytes of data via

the usual {@link #read read} and {@link #write write} methods. From the

standpoint of performance it is generally only worth mapping relatively

large files into memory

絕大多數操作系統的內存映射開銷大于IO開銷

同時通過測試結果來看,工具類和JDK提供的文件復制方法效果并不高,如果不追求效率還是可以使用一下,畢竟能少寫一行代碼就少寫一行代碼,寫代碼沒有摸魚來的快樂

總結

以上是生活随笔為你收集整理的nio java 内核拷贝_大文件拷贝,试试NIO的内存映射的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲国产aⅴ精品一区二区 日韩黄色在线视频 | 色操插 | 激情欧美一区二区免费视频 | 天堂网一区二区三区 | 91精品一区二区三 | 亚洲一区黄色 | 多啪啪免费视频 | 亚洲精品一区二区三区蜜臀 | 国产日韩欧美一区二区 | 2022天天操 | 欧美群妇大交群 | 日本一区二区三区免费在线观看 | 日韩精品一区二区三区不卡 | 中文字幕一级 | 中文字幕亚洲综合 | 中文字幕一区二区三区精品 | 丝袜五月天 | 67194av| 久久精品人妻一区二区三区 | 99国产精品国产精品九九 | 特黄特色特刺激免费播放 | 成人影视在线看 | 男人av资源 | 亚洲女同女同女同女同女同69 | 成人手机视频在线观看 | 特黄aaaaaaaaa真人毛片 | 国产91在线看| 日本美女操 | 老鸭窝视频在线观看 | 国产又粗又猛又黄又爽无遮挡 | 综合激情久久 | 亚洲精品白浆 | av资源免费 | 亚洲视频在线免费播放 | 久久精品中文字幕 | 波多野结衣av在线播放 | 一级伦理片 | 潮喷失禁大喷水无码 | 手机在线观看免费av | 国产精品美女久久久网av | 成人av一区二区三区在线观看 | 色屁屁一区二区三区视频 | 中国一级片黄色一级片黄 | 免费毛片在线播放免费 | 国产制服丝袜 | 日本在线播放一区 | 日韩在线视频二区 | 久久久久久久久久久久久久国产 | 侵犯亲女在线播放视频 | 青青操青青 | 国产精品手机在线观看 | 污污视频在线看 | 99riav国产 | 黄色片免费网站 | 国产精品国产一区二区 | 泰坦尼克号3小时49分的观看方法 | 1024你懂的日韩 | 少妇视频网站 | av影视天堂| 中文字幕乱码人妻无码久久95 | 夜夜操操| 国产精品白丝喷水在线观看 | 美女在线观看视频 | 亚洲性生活 | 精品一区欧美 | 亚州av网| 亚洲成人免费 | 美乳人妻一区二区三区 | 欧美久久一区二区三区 | 91极品尤物 | 亚洲精品久久 | 国产精品成人久久电影 | 91久久久国产精品 | 干夜夜| 美女扒开尿口让男人爽 | 成人小视频在线免费观看 | 国产精品久久国产精麻豆96堂 | 欧美超逼视频 | 日本一区二区网站 | 一区二区三区视频 | 色婷婷影院 | 久久久久久久久久久av | 91亚洲欧美激情 | 日韩精品一区二区三区电影 | 久久综合色婷婷 | 亚洲s码欧洲m码国产av | 日韩成人动漫在线观看 | 波多野结衣大片 | 亚洲视频免费在线播放 | 久本草精品 | 日韩aaa| 国产亚洲欧美一区二区 | 亚洲午夜在线 | 97超碰人人澡人人爱学生 | 丰满白嫩尤物一区二区 | 一区二区三区波多野结衣 | www.超碰| 免费国产精品视频 | 97超碰中文|