package daybyday;
/*
好处:
1.提高相应速度(减少创建新线程的时间)
2.降低资源消耗
3.便于线程管理
corePoolSize 核心池的大小
maximumPool最大线程数
keepAlivetime线程没有任务时最多保持多久时间后会终止
*/
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;

class NumberThred 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 NumberThred1 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 ;
//设置线程池的属性
service.getClass();
service1.setCorePoolSize(15);
service1.setKeepAliveTime(100);

//2.执行指定的线程的操作,需要提供Runnable或Callable接口
service.execute(new NumberThred());//适用于Runnable
service.execute(new NumberThred1());//适用于Runnable
// service.submit(); 适用于Callable
service.shutdown();//关闭线程池
}
}

原文地址:http://www.cnblogs.com/liujy2233/p/16886937.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性