Java-使用线程池创建多线程
1.概念
提前创建好多个线程,放入线程池总,使用时直接获取,使用完后放入池中,可以避免频繁创建销毁,实现重复利用
- corePoolSize:核心池的大小
- maximumPoolSize:最大线程数
- keepAliveTime:线程没任务时最多保持多长时间后会终止
2.好处
- 提高响应速度(减少了创建新线程的时间)
- 降低资源消耗(重复利用线程池中线程,不需要每次都创建)
- 便于线程管理
3.代码举例
package com.lmw.thread3;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
/**
* @author
* @version 1.0.0
* @createTime 2022/5/14 21:41
* @description
*/
public class ThreadPool {
public static void main(String[] args) {
// 提供指定线程数量的线程池
ExecutorService service = Executors.newFixedThreadPool(10);
// 强转
ThreadPoolExecutor service1 = (ThreadPoolExecutor) service;
// 设置线程池的属性
//service1.属性
// 执行指定的线程操作,需要提供实现Runnable接口或者Callable接口实现类的对象
service1.execute(new NumberThread()); //适合Runnable
// service.submit(new NumberThread1()); //适合Callable
// 关闭线程池
service1.shutdown();
}
}
class NumberThread implements Runnable {
@Override
public void run() {
for (int i = 0; i < 100; i++) {
if(i % 2 == 0) {
System.out.println(Thread.currentThread().getName() + ":" + i);
}
}
}
}