package com.dy.common.mw.core;
|
|
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.Logger;
|
|
/**
|
* @Author liurunyu
|
* @Date 2023/12/19 16:41
|
* @LastEditTime 2023/12/19 16:41
|
* @Description
|
*/
|
public class CoreConstantThread extends Thread {
|
|
private final static Logger log = LogManager.getLogger(CoreConstantThread.class.getName()) ;
|
|
private long sleepBigBusy ;
|
private long sleepSmallBusy ;
|
private CoreTask task ;
|
|
public CoreConstantThread(long sleepBigBusy, long sleepSmallBusy, CoreTask task){
|
this.sleepBigBusy = sleepBigBusy ;
|
this.sleepSmallBusy = sleepSmallBusy ;
|
this.task = task ;
|
}
|
|
@Override
|
public void run() {
|
if(task != null){
|
int count ;
|
while (true) {
|
try {
|
count = task.execute();
|
if (count == 0) {
|
//小暂停一下
|
Thread.sleep(sleepBigBusy);
|
}else{
|
Thread.sleep(sleepSmallBusy);
|
}
|
} catch (Exception e) {
|
log.error("恒久任务" + task.getClass().getName() + "执行时发生异常" + (e.getMessage() == null ? "" : (":" + e.getMessage())), e);
|
}
|
}
|
}
|
}
|
}
|