자바 nio 파일 복사
주말 에 심심 해 요.nio 를 배 웠 더 니 파일 을 읽 고 쓰 는 사람 을 가 져 왔 습 니 다. 옛날 것 과 비교 해 보 니 속도 가 정말 빨 라 졌 습 니 다. 나중에 FastCopy 라 는 작은 도 구 를 비교 해 보 니 속도 가 많이 떨 어 지지 않 았 습 니 다. FastCopy 는 직접 오른쪽 단 추 를 누 르 고 붙 이 는 것 보다 훨씬 빠 릅 니 다.다음은 코드:
package com.lucene.file;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class FileCopy {
public static String src = "f:\\ .rmvb";
public static String dist = "f:\\ 2.rmvb";
/**
* @param args
*/
public static void main(String[] args) {
long start = System.currentTimeMillis();
copyOld();
long end = System.currentTimeMillis();
System.out.println("nio : " + (end - start));
long start2 = System.currentTimeMillis();
copyOld();
end = System.currentTimeMillis();
System.out.println("io : " + (end - start2));
}
public static void copyOld() {
File srcFile = new File(src);
File distFile = new File(dist);
if (distFile.exists()) {
distFile.delete();
}
try {
FileInputStream fin = new FileInputStream(srcFile);
BufferedInputStream buffIn = new BufferedInputStream(fin);
FileOutputStream fout = new FileOutputStream(distFile);
BufferedOutputStream buffout = new BufferedOutputStream(fout);
byte[] bytes = new byte[1024];
while (buffIn.read(bytes) > 0) {
buffout.write(bytes);
}
fin.close();
buffIn.close();
fout.close();
buffout.close();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void copyNew() {
try {
File srcFile = new File(src);
File distFile = new File(dist);
if (distFile.exists()) {
distFile.delete();
}
FileInputStream fin = new FileInputStream(srcFile);
FileOutputStream fout = new FileOutputStream(distFile);
FileChannel inChannel = fin.getChannel();
FileChannel outChannel = fout.getChannel();
int ByteBufferSize = 1024 * 100;
ByteBuffer buff = ByteBuffer.allocate(ByteBufferSize);
while (inChannel.read(buff) > 0) {
buff.flip();
if (inChannel.position() == inChannel.size()) {//
int lastRead = (int) (inChannel.size() % ByteBufferSize);
byte[] bytes = new byte[lastRead];
buff.get(bytes, 0, lastRead);
outChannel.write(ByteBuffer.wrap(bytes));
buff.clear();
} else {
outChannel.write(buff);
buff.clear();
}
}// FileChannel
// outChannel.transferFrom(inChannel, 0, inChannel.size());
outChannel.close();
inChannel.close();
fin.close();
fout.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.