package DayTest23;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
/**
* 创建线程方式四:使用线程池
* 好处:1.提高响应速度(减少了创建线程的时间)
* 2.降低资源消耗(重复利用线程池中的线程,不需要每次都创建)
* 3.便于线程管理
* corePoolSize:核心池的大小
* maximumPoolSize:对打线程数
* keepAliveTime:线程没有任务是最多保持多长时间后会终止
* @author 冀帅
* @date 2020/8/6-10:05
*/
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);
}
}
}
}
class NumberThread1 implements Runnable{
@Override
public void run() {
for (int i = 0; i <=100 ; i++) {
if (i%2!=0){
System.out.println(Thread.currentThread().getName()+":"+i);
}
}
}
}
public class ThreadPool {
public static void main(String[] args) {
//1.提供指定线程数量的线程池
ExecutorService service = Executors.newFixedThreadPool(10);
ThreadPoolExecutor service1 = (ThreadPoolExecutor) service;
//设置线程池的属性
//System.out.println(service.getClass());//获取接口ExecutorService的实现类
service1.setCorePoolSize(15);
//service1.setKeepAliveTime();
//2.执行指定线程的操作,需要提供一个实现Runnanle接口或者Callable接口实现类的对象
service.execute(new NumberThread());//适合使用Runnable
service.execute(new NumberThread1());//适合使用Runnable
// service.submit(Callable callable);//适合适用于Callable
//3.关闭连接池
service.shutdown();
}
}