当对大批数据进行操作时,我们首先想到就是使用多线程,
多线程的返回值可有可无,但有返回值的线程可以控制线程的批次
首先新建一个类,实现Callable<Boolean(可以返回任意类型)>接口
实现这个接口以后需要实现call方法,在这个方法编写需要处理的流程
import java.util.concurrent.Callable;
import java.util.concurrent.TimeUnit;
public class CallableTest implements Callable<Boolean>{
private String str;
public CallableTest() {
// TODO Auto-generated constructor stub
}
public CallableTest(String str) {
this.str=str;
}
@Override
public Boolean call() throws Exception {
System.out.println(str);
// Thread.sleep(2000);
// TimeUnit.SECONDS.sleep(2);
// Thread.yield();
return true;
}
}
下面是测试方法
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class test {
public static void main(String[] args) throws InterruptedException, ExecutionException {
ExecutorService pool=Executors.newCachedThreadPool();
List<Future<Boolean>> poolList=new ArrayList<Future<Boolean>>();
for (int i = 0; i < 25; i++) {
Callable<Boolean> call=new CallableTest(String.valueOf(i));
poolList.add(pool.submit(call));
System.out.println("次数:"+i);
}
pool.shutdown();
//
for (Future<Boolean> future : poolList) {
//可以在这里接受方法的返回值
future.get();
}
System.out.println("一批线程");
}
}
随便写个简单的调用,有点懒,凑合看吧,有什么问题在单独发表