java中 ExecutorService,Executor,ThreadPoolExecutor的用法
2017-07-10 15:56
169 查看
package com; import java.util.concurrent.BlockingQueue; import java.util.concurrent.Executor; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; public class demo3 { public static void main(String[] args) { // TODO Auto-generated method stub //test1(); //test2(); test3(); } static void test1(){ //ExecutorService的用法 ExecutorService fixedThreadPool = Executors.newFixedThreadPool(2); for( int i=0;i<100;i++){ fixedThreadPool.execute( new Runnable(){ public void run() { System.out.println("====threadId="+Thread.currentThread().getId()); } } ); } } static void test2(){ Executor exec=new ThreadPerTaskExecutor(); exec.execute(new Runnable(){ @Override public void run() { // TODO Auto-generated method stub System.out.println("ccccc"+Thread.currentThread().getId()); } }); } //ThreadPoolExecutor static void test3(){ BlockingQueue<Runnable> queue = new LinkedBlockingQueue<Runnable>(); ThreadPoolExecutor threadPool = new ThreadPoolExecutor(2, 4, 5, TimeUnit.SECONDS, queue, new ThreadPoolExecutor.AbortPolicy()); for(int i=0;i<100;i++){ threadPool.execute(new MyThread(i+"")); } threadPool.shutdown(); } static class MyThread implements Runnable { private String name; public MyThread(String name) { this.name = name; } @Override public void run() { // 做点事情 try { Thread.sleep(1000); System.out.println(name+"===当前线程="+Thread.currentThread().getId() + " finished job!") ; } catch (InterruptedException e) { e.printStackTrace(); } } } } //execute的用法 class ThreadPerTaskExecutor implements Executor { public void execute(Runnable r) { new Thread(r).start(); } }
相关文章推荐
- Java并发专题 带返回结果的批量任务运行 CompletionService ExecutorService.invokeAll
- [Java线程] Java线程池ExecutorService
- Java并发编程 - Executor,Executors,ExecutorService, CompletionServie,Future,Callable
- Java线程池(Android拥有与Java相同的ExecutorService实现)
- 开源一个基于Java ExecutorService的线程池包装类ARTaskQueue
- JAVA线程池ScheduledExecutorService周期性地执行任务 与单个Thread周期性执行任务的异常处理
- java多线程并发executorservice(任务调度)类
- JAVA生产者与消费者模式 BlockingQueue与ExecutorService实例
- Java并发编程之Future,ExecutorService,Callable讲解实例
- Java线程池ExecutorService
- 【Java线程】Java线程池ExecutorService
- Android(Java) 线程池ExecutorService 使用的注意事项
- JAVA并行编程,线程池+FutureTask+callable+ExecutorService
- Java线程池 ExecutorService
- java多线程:ExecutorService解析(五)
- java并发库之Executors常用的创建ExecutorService的几个方法说明
- Java 多线程中关于 ExecutorService 和 CompletionService的讨论
- java基础巩固---线程池ExecutorService
- 共同学习Java源代码-多线程与并发-AbstractExecutorService类(二)
- java ListeningExecutorService线程池的实现