import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class ThreadPoolDynamicTasks extends Thread {
private BlockingQueue<Runnable> bq = new LinkedBlockingQueue<>();// 可將此隊列注入到客戶端的子模塊中
private ExecutorService es = new ThreadPoolExecutor(2, 4, 0, TimeUnit.SECONDS, bq);
private void init() {
try {
bq.put(new Runnable() {
@Override
public void run() {
while (true) {
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("添加的任務");
}
}
});
bq.put(new Runnable() {
@Override
public void run() {
// while (true) {
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("AAAAAA");
// }
}
});
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
ThreadPoolDynamicTasks instance = new ThreadPoolDynamicTasks();
instance.init();// 阻塞隊列中添加任務
instance.start();// 利用線程循環遍歷阻塞隊列,每執行一個任務就移除一個任務
instance.getTaskLengSize();// 獲取阻塞隊列里的任務數量
try {
Thread.sleep(3000);
instance.addTask();// 在main線程中中途添加阻塞隊列
instance.getTaskLengSize();// 獲取阻塞隊列里的任務數量
Thread.sleep(1000);
instance.getTaskLengSize();// 獲取阻塞隊列的任務數量
} catch (InterruptedException e) {
e.printStackTrace();
}
}
@Override
public void run() {
while (true) {
for (Runnable runnable : bq) {
// try {
// bq.take();
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
es.execute(runnable);
bq.remove(runnable);
}
}
}
private void addTask() {
try {
bq.put(new Runnable() {
@Override
public void run() {
while (true) {
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("~~~~~~~~~~~");
}
}
});
// es.execute(command);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
private void getTaskLengSize() {
System.out.println(bq.size());
}
}
只要將任務隊列注冊到上下文容器中(例如web應用的servletContext、Eclipse應用的EclipseContext),注冊到需要執行任務的java文件里,就可以用一個線程池執行所有的任務。
