JAVA多线程处理for循环
程序员文章站
2022-06-28 13:01:52
public static void main(String[] args) { long start = System.currentTimeMillis(); List list = new ArrayList(); for (int i = 0; i < 1000; i++) { list.add(i); } //定义线程数量为20,可根据服务器配置适当调整大小...
public static void main(String[] args) {
long start = System.currentTimeMillis();
List<Integer> list = new ArrayList();
for (int i = 0; i < 1000; i++) {
list.add(i);
}
//定义线程数量为20,可根据服务器配置适当调整大小
Thread(list, 20);
long end = System.currentTimeMillis();
System.out.println("总时间 = " + (end - start));
}
//此处有加锁,不需要的同学可以自行改造
public synchronized static <T> void Thread(List<T> list, int nThread) {
if (CollectionUtils.isEmpty(list) || nThread <= 0 || CollectionUtils.isEmpty(list)) {
return;
}
Semaphore semaphore = new Semaphore(nThread);//定义几个许可
ExecutorService executorService = Executors.newFixedThreadPool(nThread);//创建一个固定的线程池
for (T number : list) {
try {
semaphore.acquire();
executorService.execute(() -> {
//此处可以放入待处理的业务
System.out.println("number:" + number);
semaphore.release();
});
} catch (InterruptedException e) {
}
}
executorService.shutdown();
}
在数据量大的情况下对比直接循环效果很明显。用上之后又可以加鸡腿了~
本文地址:https://blog.csdn.net/JST888_K/article/details/111865941
上一篇: 前端面试题