ExecutorService比复制文件的顺序文件进程慢

时间:2014-03-13 12:14:42

标签: java synchronized executorservice

这是我使用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();
    }
  }

 }

1 个答案:

答案 0 :(得分:4)

  

有什么问题?

我真的不明白为什么你会认为线程池可以加速文件传输。试试这个:运行你的单线程版本并监控CPU使用情况。我的期望:它将低于10%。

文件复制不是CPU密集型操作,而且并行化只意味着您创建了一个困难的磁盘访问模式,这会减慢整个过程,并可能导致更多的文件碎片。