Tout d'abord, introduisez le Java timer (java.util.Timer) qui a pour fonction d'exécuter régulièrement les tâches planifiées en définissant l'intervalle du minuteur, il s'exécutera automatiquement après cet intervalle <.> Tâches pré-planifiées (java.util. TimerTask)
est l'exécution. Le temps d'attente avant la tâche, où 0 signifie pas d'attente, le troisième paramètre est le temps d'intervalle, en millisecondes.
Mais :/** * 定时任务测试类 * @author admin * */ public class TimerScheduleDemo extends TimerTask { public TimerScheduleDemo() { } @Override public void run() { print(); } public static void main(String[] args) { Timer timer = new Timer(); long delay1 = 1 * 1000; long period1 = 1000; // 从现在开始 1*1000 秒钟之后,每隔 1 秒钟执行一次 timer.schedule(new TimerScheduleDemo(), delay1, period1); /*long delay2 = 2 * 1000; long period2 = 2000; // 从现在开始 2 秒钟之后,每隔 2 秒钟执行一次 timer.schedule(new TimerScheduleDemo(), delay2, period2); */ } public static void print(){ System.out.println("method start"); } }
Parce que nous espérons que lorsque le projet Web démarre, le minuteur pourra démarrer automatiquement le chronométrage, afin que tout au long de la vie du projet Web, les tâches soient exécutées régulièrement. Par conséquent, la classe qui démarre le timer ne peut pas être une classe générale. Ici, la classe d'écoute Servlet est utilisée pour démarrer le timer en configurant cet écouteur dans le fichier de configuration, laissez-le se charger et s'exécuter automatiquement au démarrage du projet, et sa survie. La période correspond à l’ensemble du cycle de vie du projet Web.
Code métier principal de la classe de tâches
Cette classe hérite principalement de TimerTask et implémente sa méthode d'exécution/** * 定时器任务类:即调度任务类 * @author admin */ public class DelFileTask extends TimerTask{ private static boolean isRunning = false; private ServletContext context = null; public DelFileTask() { super(); } public DelFileTask(ServletContext context) { this.context = context; } @Override public void run() { if (!isRunning) { context.log("开始执行指定任务"); /** * 自己的业务代码 */ isRunning = false; context.log("指定任务执行结束"); } else { context.log("上一次任务执行还未结束"); } } }
Ce qui suit est la classe d'écoute pour surveiller le démarrage du serveur et Ajouter des tâches à la pile de tâches
Cette classe est principalement utilisée pour configurer un planificateur et lui permettre d'exécuter des tâches selon certaines exigences./** * servlet监听器:监听服务启动时执行调度任务 * @author admin * */ public class ContextListener implements ServletContextListener{ public ContextListener() { } private java.util.Timer timer = null; /** * 初始化定时器 * web 程序运行时候自动加载 */ @Override public void contextInitialized(ServletContextEvent arg0) { /** * 设置一个定时器 */ timer = new java.util.Timer(true); arg0.getServletContext().log("定时器已启动"); /** * 定时器到指定的时间时,执行某个操作(如某个类,或方法) */ //设置执行时间 Calendar calendar =Calendar.getInstance(); int year = calendar.get(Calendar.YEAR); int month = calendar.get(Calendar.MONTH); int day =calendar.get(Calendar.DAY_OF_MONTH);//每天 //定制每天的16:10:00执行, calendar.set(year, month, day, 16, 10, 00); Date date = calendar.getTime(); System.out.println(date); int period = 1000; //每天的date时刻执行task,每隔persion 时间重复执行 timer.schedule(new DelFileTask(arg0.getServletContext()), date, period); //在 指定的date时刻执行task, 仅执行一次 //timer.schedule(new DelFileTask(arg0.getServletContext()), date); arg0.getServletContext().log("已经添加任务调度表"); } /** * 销毁 */ @Override public void contextDestroyed(ServletContextEvent arg0){ timer.cancel(); arg0.getServletContext().log("定时器销毁"); } }
La classe d'écouteur de tâches a été implémentée. L'étape suivante consiste à configurer l'écouteur dans le Web
Recommandations associées :
<listener> <listener-class>ContextListener</listener-class> </listener>
Exemples d'utilisation de minuteries et de tâches planifiées. en Java
Comment utiliser Java timer Timer-java tutoriel
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!