Java NIO FileChannel a wydajność / użyteczność FileOutputstream
Próbuję dowiedzieć się, czy istnieje jakakolwiek różnica w wydajności (lub korzyściach), gdy używamy nioFileChannel
kontra normalnyFileInputStream/FileOuputStream
czytać i zapisywać pliki do systemu plików. Zauważyłem, że zarówno na moim komputerze, jak i na tym samym poziomie, również wielokrotnieFileChannel
sposób jest wolniejszy. Czy mogę znać więcej szczegółów porównując te dwie metody. Oto kod, którego użyłem, plik, który testuję, jest w pobliżu350MB
. Czy dobrym rozwiązaniem jest używanie klas opartych na NIO dla we / wy plików, jeśli nie szukam dostępu losowego lub innych tak zaawansowanych funkcji?
package trialjavaprograms;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class JavaNIOTest {
public static void main(String[] args) throws Exception {
useNormalIO();
useFileChannel();
}
private static void useNormalIO() throws Exception {
File file = new File("/home/developer/test.iso");
File oFile = new File("/home/developer/test2");
long time1 = System.currentTimeMillis();
InputStream is = new FileInputStream(file);
FileOutputStream fos = new FileOutputStream(oFile);
byte[] buf = new byte[64 * 1024];
int len = 0;
while((len = is.read(buf)) != -1) {
fos.write(buf, 0, len);
}
fos.flush();
fos.close();
is.close();
long time2 = System.currentTimeMillis();
System.out.println("Time taken: "+(time2-time1)+" ms");
}
private static void useFileChannel() throws Exception {
File file = new File("/home/developer/test.iso");
File oFile = new File("/home/developer/test2");
long time1 = System.currentTimeMillis();
FileInputStream is = new FileInputStream(file);
FileOutputStream fos = new FileOutputStream(oFile);
FileChannel f = is.getChannel();
FileChannel f2 = fos.getChannel();
ByteBuffer buf = ByteBuffer.allocateDirect(64 * 1024);
long len = 0;
while((len = f.read(buf)) != -1) {
buf.flip();
f2.write(buf);
buf.clear();
}
f2.close();
f.close();
long time2 = System.currentTimeMillis();
System.out.println("Time taken: "+(time2-time1)+" ms");
}
}