关于超时任务的实现
package test.thread;import java.util.Timer;import java.util.TimerTask;public class MainThread {private Object lock = new Object();public void waitLock() throws InterruptedException {synchronized (lock) {lock.wait();}}public void notifyLock() {synchronized (lock) {lock.notify();}}/** * @param args * 关于超时任务的实现 实现功能:处理一批任务,如果某个任务的处理时间超过最大处理时间,则终止该任务的执行,继续执行下一个任务 * 实现思路:三线程实现,处理一个任务时,启动一个任务处理线程处理方案,再启动一个定时器线程检测是否超时,并通过一个同步变量保证任务时串行执行的。 * @throws InterruptedException */public static void main(String[] args) {MainThread mainThread = new MainThread();for (int i = 2; i <= 20; i += 2) {System.out.println("start task!" + i);ProccessThread proccessThread = new ProccessThread(mainThread,i * 1000);MonitorThread monitorThread = new MonitorThread(mainThread);long maxProccessTime = 8 * 1000;// 每个任务的最大处理时间Timer timer = new Timer();timer.schedule(monitorThread, maxProccessTime);proccessThread.start();try {mainThread.waitLock();} catch (InterruptedException e) {e.printStackTrace();}proccessThread.stop();timer.cancel();System.out.println("end task!" + i);}}}/** * 定时器线程检测 * @author liuhui * */class MonitorThread extends TimerTask {private MainThread mt;public MonitorThread(MainThread mt) {super();this.mt = mt;}@Overridepublic void run() {System.out.println("ThreadID:" + " MonitorThread running!");mt.notifyLock();}}/** * 任务处理线程 * @author liuhui * */class ProccessThread implements Runnable {private MainThread mt;private Thread thread;private long processTime;public static int sec = 1;public ProccessThread(MainThread mt, long processTime) {super();this.mt = mt;this.processTime = processTime;}private void doSomething() {try {// do something// thread.sleep(100*1000); //异常情况// thread.sleep(1*1000); //正常情况thread.sleep(processTime); // 正常情况System.out.println("ThreadID:" + thread.getId() + ">>> Normal Process! processTime=" + processTime);} catch (InterruptedException e) {// e.printStackTrace();System.out.println("ThreadID:" + thread.getId() + ">>> AbNormal Proccess! processTime=" + processTime);}}public void run() {System.out.println("ThreadID:" + thread.getId() + ">>> starting!");doSomething();mt.notifyLock();System.out.println("ThreadID:" + thread.getId() + ">>> ending ok!");}public void start() {thread = new Thread(this);thread.start();}public void stop() {thread.interrupt();// 如果任务在正常时间内不能退出,认为产生interrupt,强行地退出 (run方法正常结束)thread.stop();try {Thread.sleep(sec * 1000);} catch (InterruptedException e) {e.printStackTrace();}l-align:middle; margin-right: 10px;" /> 您还没有登录,请您登录后再发表评论