java线程池应用案例
线程池的简单案例,让自己简单的认识常用的几种线程池。
废话不多说,上代码。
先创建一个MyThread 类,要继承 Thread 类来创建线程。
public class MyThread extends Thread{
private int i;
public MyThread(int in) {
this.i = in;
}
public void run() {
try {
this.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(currentThread().getName()+"正在打印:"+i);
}
}
再创建一个 MyThreadText 测试类 ,分别创建4个不同 的线程池进行测试。
public class MyThreadText {
public static void main(String[] args) {
/*shutdown():不会立即终止线程池,而是要等所有任务缓存队列中的任务都执行完后才终止,但再也不会接受新的任务
shutdownNow():立即终止线程池,并尝试打断正在执行的任务,并且清空任务缓存队列,返回尚未执行的任务*/
//1.创建单个线程,用来操作一个无界的队列任务,不会使用额外的线程。如果线程崩溃会重新创建一个,直到任务完成。
ExecutorService executorService1 = Executors.newSingleThreadExecutor();
for (int i = 0; i < 10; i++) {
executorService1.execute(new MyThread(i));
}
//shutdown():不会立即终止线程池,而是要等所有任务缓存队列中的任务都执行完后才终止,但再也不会接受新的任务
executorService1.shutdown();
/* newFixedThreadPool(固定大小线程池)
2. 创建一个可重用固定线程集合的线程池,以共享的无界队列方式来运行这些线程(只有要请求的过来,就会在一个队列里等待执行)。
如果在关闭前的执行期间由于失败而导致任何线程终止,那么一个新线程将代替它执行后续的任务(如果需要)。*/
ExecutorService executorService2 = Executors.newFixedThreadPool(5);
for (int i = 0; i < 10; i++) {
executorService2.execute(new MyThread(i));
}
//shutdown():不会立即终止线程池,而是要等所有任务缓存队列中的任务都执行完后才终止,但再也不会接受新的任务
executorService2.shutdown();
//3.创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。
ExecutorService executorService3 = Executors.newCachedThreadPool();
for (int i = 0; i < 10; i++) {
executorService3.execute(new MyThread(i));
}
executorService3.shutdown();
//4.创建一个定长线程池,支持定时及周期性任务执行
ExecutorService executorService4 = Executors.newScheduledThreadPool(1);
for (int i = 0; i < 10; i++) {
executorService4.execute(new MyThread(i));
}
executorService4.shutdown();
}
}
后面再对线程池进行深入了解。