複数のファイルを並行して処理する必要があるという要件があります。
long start = System.currentTimeMillis();
File [] files=new File("C:\\ftp").listFiles();
//System.out.println(files.length);
ExecutorService executor=Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
// System.out.println("available processors.."+Runtime.getRuntime().availableProcessors());
if(files.length>=1)
{
for(int i = 0;i<files.length; i++){
System.out.println("reading..."+i);
Runnable workerThread = new FileWorkerThread(files[i]);
executor.execute(workerThread);
}
executor.shutdown();
while (!executor.isTerminated()) {
}
//次に、基本的にファイルの読み取り/書き込みを行う run() があります。これは良いアプローチですか?それを改善するためにできることはありますか?