java 线程池 优雅停止

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;

/**
* @author 201409150096
*
*/
public class ThreadTestCase extends Thread {

private boolean status;
private ArrayBlockingQueue<String> q;
private Object lock;

public ThreadTestCase(ArrayBlockingQueue<String> q) {
this.status = true;
lock = new Object();
this.q = q;
}

public void shutdown() {
synchronized (lock) {
this.status = false;
System.out.println("TT-shutdown()-call");
}
}

public void interrupt() {
System.out.println("TT-interrupt()-call");
super.interrupt();
}

public void run() {
int j = 0;
while ((!this.currentThread().isInterrupted()) && status) {
try {
int sum = 0;
// System.out.println(Thread.currentThread().getThreadGroup()
// + "----" + Thread.currentThread().getName());
// try {
// j=11;
q.take();
for (int i = 0; i < 1000000; i++) {
sum++;
}
System.out.println(Thread.currentThread().getName() + "|" + sum
+ "|" + this.currentThread().isInterrupted());
// int i = -1;
// while (i > 0) {
// this.sleep(1);
// }
} catch (InterruptedException e) {
this.shutdown();
// e.printStackTrace();
System.out.println("InterruptedException");
}
// } catch (IllegalMonitorStateException e) {
// this.shutdown();
// e.printStackTrace();
// System.out.println("IllegalMonitorStateException");
// }
}
}

/**
* @param args
*/
public static void main(String[] args) {
System.out.println("start");
ArrayBlockingQueue<String> q = new ArrayBlockingQueue<String>(100);
for (int i = 0; i < 100; i++) {
try {
q.put(i + "");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
List<ThreadTestCase> threadList = new ArrayList<ThreadTestCase>();

// for (int i = 0; i < 10; i++) {
// TT t = new TT();
// threadList.add(t);
// t.start();
// }
ThreadPoolExecutor ex = (ThreadPoolExecutor) Executors
.newFixedThreadPool(10);
for (int i = 0; i < 3; i++) {
ThreadTestCase t = new ThreadTestCase(q);
threadList.add(t);
ex.execute(t);
}

while (ex.getPoolSize() < 3) {
System.out.println("main-sleep");
}
// for (int i = 0; i < threadList.size(); i++) {
// Thread t = threadList.get(i);
// try {
// t.join();
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
//
// }
try {
Thread.sleep(5);
} catch (InterruptedException e) {
e.printStackTrace();
}

for (int i = 0; i < threadList.size(); i++) {
ThreadTestCase t = threadList.get(i);
// t.interrupt();
// t.shutdown();
}
// ex.shutdown();
// ex.join();\
int t = 5;
while (t-- > 0) {
// try {
// Thread.sleep(1000);
// } catch (InterruptedException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
// ex.shutdown();
System.out.println("ex.shutdownNow" + ex.shutdownNow());
}

System.out.println("end" + q.size());
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java 线程池工厂类是一种构建线程池的工具类,其通过提供线程池配置参数来构造线程池对象。通常来说,线程池工厂类会提供一些静态方法,用于创建不同类型的线程池,如单线程池、固定大小的线程池、可扩展的线程池等。 Java 标准库中提供了 `Executors` 类作为线程池工厂类。例如,你可以使用以下代码创建一个固定大小的线程池: ``` ExecutorService executor = Executors.newFixedThreadPool(5); ``` 这里的 `executor` 就是线程池对象。你也可以使用以下代码创建一个单线程的线程池: ``` ExecutorService executor = Executors.newSingleThreadExecutor(); ``` 另外,Java 还提供了一个 `ThreadPoolExecutor` 类来提供更多细节的线程池定制能力。你可以使用 `ThreadPoolExecutor` 类的构造函数来创建线程池,并通过指定线程池的配置参数来控制线程池的行为。 总的来说,线程池工厂类是一种方便的工具,可以帮助你快速构建线程池,并且提供了多种选择,以满足不同的需求。 ### 回答2: Java线程池工厂类是一个用于创建和管理线程池的类。它提供了一种方便的方式来创建和重用线程,从而实现线程的高效使用。 在Java中,线程池是一种管理和控制线程的机制,它可以将任务提交给线程执行,而不是每次都创建新的线程。这种方式避免了频繁地创建和销毁线程的开销,提高了系统的性能和响应速度。 Java线程池工厂类通过提供一系列静态方法来创建不同类型的线程池,比如FixedThreadPool,CachedThreadPool和ScheduledThreadPool等。这些方法返回一个实现了ExecutorService接口的线程池对象,通过这个对象可以管理线程池的状态和操作。 线程池工厂类的创建线程池的方法通常包含一些参数,比如核心线程数、最大线程数、线程空闲时间、任务队列等,通过这些参数可以灵活地配置线程池以满足具体的业务需求。 线程池工厂类还提供了一些管理线程池的方法,比如提交任务、关闭线程池、获取线程池状态等。通过这些方法可以方便地向线程池提交任务,并且在需要的时候可以优雅关闭线程池。 总之,Java线程池工厂类是一个非常重要的类,它提供了一种简单且高效的方式来管理和重用线程,有助于提高系统的性能和可扩展性。 ### 回答3: Java线程池工厂类是用来创建和管理线程池的类。线程池可以有效地管理线程的创建和销毁,提高程序的效率和性能。 在Java中,可以使用ThreadPoolExecutor类来创建线程池线程池工厂类是为线程池的创建和配置提供便捷方法的工具类。它可以根据需要返回不同类型的线程池,比如固定大小的线程池、缓存线程池或定时任务线程池线程池工厂类提供了一系列的静态方法,可以根据预定义的参数来创建线程池。比如,可以通过指定线程池的最小和最大线程数、线程的空闲时间等参数来创建一个固定大小的线程池。也可以通过设置线程池的最大线程数为无限大,来创建一个缓存线程池。 除了创建线程池线程池工厂类还提供了一些其他的方法,用于执行任务或关闭线程池。可以通过submit()方法将任务提交给线程池执行,也可以通过shutdown()方法关闭线程池停止所有线程的执行。 总的来说,Java线程池工厂类是一个方便的工具类,可以用于创建和管理线程池。通过使用线程池工厂类,可以避免手动创建和管理线程的繁琐工作,提高程序的可维护性和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值