这是我使用ExecutorService
将文件从一个目录复制到另一个目录的代码,但结果却比顺序操作慢。我使用的是未经同步的apache FileUtils copyFile方法。问题是什么?
public class ExecutorService {
private static java.util.concurrent.ExecutorService pool;
public ExecutorService() {
pool = Executors.newFixedThreadPool(20);
}
public static void main(String arg[]) {
long a = System.currentTimeMillis();
new ExecutorService();
List<File> listFiles = null;
try {
listFiles = FileUtility.getFileNamesToExtract(new File(
"C:/Users/User/Desktop/XSLT Source/Input XML"));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
for (int i = 0; i < listFiles.size(); i++)
pool.submit(new FileTransfer(listFiles.get(i), i));
pool.shutdown();
try {
pool.awaitTermination(Long.MAX_VALUE, TimeUnit.NANOSECONDS);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
long b = System.currentTimeMillis();
System.out.println((b - a) / 1000);
}
}
public class FileTransfer implements Runnable{
private File file = null;
private int num = 0;
public FileTransfer(File file, int i) {
this.file = file;
this.num = i;
}
@Override
public void run() {
try {
System.out.println("Processing="+file.getName());
FileUtils.copyFile(file, new File("C:/Users/gursahibsahni/Desktop/thread pool files/"+num+"_"+file.getName()+num));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
答案 0 :(得分:4)
有什么问题?
我真的不明白为什么你会认为线程池可以加速文件传输。试试这个:运行你的单线程版本并监控CPU使用情况。我的期望:它将低于10%。
文件复制不是CPU密集型操作,而且并行化只意味着您创建了一个困难的磁盘访问模式,这会减慢整个过程,并可能导致更多的文件碎片。