首页 > 代码库 > Java多线程——Executors和线程池
Java多线程——Executors和线程池
线程池的概念与Executors类的应用
1.创建固定大小的线程池
package java_thread; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; public class ThreadPoolTest { /** * @param args */ public static void main(String[] args) { ExecutorService threadPool = Executors.newFixedThreadPool(3); // ExecutorService threadPool = Executors.newCachedThreadPool(); // ExecutorService threadPool = Executors.newSingleThreadExecutor(); for(int i=1;i<=10;i++){ final int task = i; threadPool.execute(new Runnable(){ @Override public void run() { for(int j=1;j<=4;j++){ try { Thread.sleep(20); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(Thread.currentThread().getName() + " is looping of " + j + " for task of " + task); } } }); } System.out.println("all of 10 tasks have committed! "); //threadPool.shutdownNow(); // Executors.newScheduledThreadPool(3).scheduleAtFixedRate( // new Runnable(){ // @Override // public void run() { // System.out.println("bombing!"); // // }}, // 6, // 2, // TimeUnit.SECONDS); } }
2.创建缓存线程池
ExecutorService threadPool = Executors.newCachedThreadPool();
3.创建单一线程池
ExecutorService threadPool = Executors.newSingleThreadExecutor();
关闭线程池
shutdown与shutdownNow的比较
threadPool.shutdownNow();
用线程池启动定时器
调用ScheduledExecutorService的schedule方法,返回的ScheduleFuture对象可以取消任务。
支持间隔重复任务的定时方式,不直接支持绝对定时方式,需要转换成相对时间方式。
Executors.newScheduledThreadPool(3).scheduleAtFixedRate( //多久气候执行,每隔多久执行 new Runnable(){ @Override public void run() { System.out.println("bombing!"); }}, 6, 2, TimeUnit.SECONDS);
Java多线程——Executors和线程池
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。