Heim >Java >javaLernprogramm >So verwenden Sie den Java-Timer Timer
Die Timer-Funktion löst innerhalb des angegebenen Zeitintervalls wiederholt das Timer-Ereignis des angegebenen Fensters aus. Syntax Timer (Intervall {, Fenstername }) Parameterintervall: Geben Sie das Zeitintervall zwischen dem zweimaligen Auslösen des Timer-Ereignisses an. Der gültige Wert liegt zwischen 0 und 65. In diesem Artikel wird hauptsächlich die Verwendung des Java-Timers im Detail vorgestellt, der einen bestimmten Referenzwert hat.
Die Funktion für geplante Aufgaben in Java verwendet hauptsächlich das Timer-Objekt, das Multithreading für die interne Verarbeitung verwendet, sodass es immer noch sehr eng mit der Multithreading-Technologie verwandt ist. Im JDK ist die Timer-Klasse hauptsächlich für die Funktion der Planung von Aufgaben verantwortlich, dh für das Starten einer Aufgabe zu einem bestimmten Zeitpunkt. Die Klasse, die die Aufgabe kapselt, ist jedoch die TimerTask-Klasse.
Passen Sie die auszuführenden Aufgaben an, indem Sie die TimerTask-Klasse erben und die run()-Methode implementieren:
public class Mytask extends TimerTask { @Override public void run() { DateFormat dateFormat = TimeUtil.df.get(); System.out.println("我的任务运行了" + dateFormat.format(new Date())); } }
Führen Sie die Aufgabe zur Ausführungszeit aus, indem Sie Timer.schedule(TimerTask task,Date time) ausführen:
public class Run { private static Timer timer=new Timer(); public static void main(String[] args) throws ParseException { timer.schedule(new Mytask(), TimeUtil.df.get().parse("2017-09-14 09:19:30")); } }
Hinweis: Stellen Sie sicher, dass die Zeitkonvertierungstoolklasse sichergestellt ist Thread-Sicherheit:
public class TimeUtil { public static final ThreadLocal<DateFormat> df = new ThreadLocal<DateFormat>() { @Override protected DateFormat initialValue() { return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); } }; }
2. Hinweise zur Timer-Klasse
1 Objekt ist ein neuer Thread, aber dieser neu gestartete Thread ist kein Daemon-Thread. Er wurde im Hintergrund ausgeführt. Sie können den neu gestarteten Timer-Thread wie folgt festlegen.
private static Timer timer=new Timer(true);
2. Vorrücken: Wenn die geplante Zeit vor der aktuellen Zeit liegt, wird die Aufgabe sofort ausgeführt.
3. Verzögerung: TimerTask wird nacheinander in einer Warteschlange ausgeführt, sodass die Ausführungszeit möglicherweise nicht mit Ihrer erwarteten Zeit übereinstimmt, da die vorherige Aufgabe möglicherweise länger dauert und die nachfolgenden Aufgaben Die Ausführungszeit dauert sich verzögern. Die spezifische Startzeit der verzögerten Aufgabe basiert auf der „Endzeit“ der vorherigen Aufgabe
4. Periodischer Betrieb: Timer.schedule(TimerTask task, Date firstTime, langer Zeitraum) Führen Sie die Aufgabe alle Millisekunden aus, beginnend mit der ersten Zeit:
5. Die aktuelle Zeit ist die Referenzzeit und die Verzögerung Basierend auf dieser Zeit wird nach der angegebenen Anzahl von Millisekunden eine TimerTask-Aufgabe ausgeführt.
6. Zeitplan (TimerTask-Aufgabe, lange Verzögerung, langer Zeitraum) Die aktuelle Zeit ist die Referenzzeit. Basierend darauf wird die angegebene Anzahl von Millisekunden verzögert und dann wird eine bestimmte Aufgabe unbegrenzt ausgeführt Mal in einem bestimmten Abstand.
7. Was ist der Unterschied zwischen cancel() von Timer und cancel() von TimerTask?
Wie bereits erwähnt, werden Aufgaben nacheinander in einer Warteschlange ausgeführt. TimerTask.cancel() bezieht sich auf das Abbrechen der aktuellen Aufgabe aus der Aufgabenwarteschlange. Der Wert von Timer.cancel() besteht darin, alle Aufgaben in der aktuellen Aufgabenwarteschlange abzubrechen. Es ist erwähnenswert, dass cancel() des Timers manchmal nicht unbedingt die Ausführung der geplanten Aufgabe stoppt, sondern sie normal ausführt. Dies liegt daran, dass die Methode cancel() in der Timer-Klasse manchmal nicht um die Warteschlangensperre konkurriert, sodass die Aufgaben in der TimerTask-Klasse weiterhin normal ausgeführt werden.
3. Der Unterschied zwischen ScheduleAtFixedRate(TimerTask task,Date firstTime,long period) und scheme(TimerTask task,Date firstTime,long period)
Gleiche Punkte:
1. Der Methodenplan und der MethodenplanAtFixedRate werden der Reihe nach ausgeführt, daher besteht keine Notwendigkeit, die Nicht-Thread-Sicherheit zu berücksichtigen.
2. Methodenplan und MethodenplanAtFixedRate Wenn die Ausführungszeit der Aufgabe nicht verzögert wird, wird die Ausführungszeit der nächsten Aufgabe anhand der „Startzeit“ der vorherigen Aufgabe berechnet.
3. Methodenplan und MethodenplanAtFixedRate Wenn sich die Ausführungszeit der Aufgabe verzögert, wird die Ausführungszeit der nächsten Aufgabe anhand des Zeitpunkts berechnet, zu dem die vorherige Aufgabe „beendet“ wurde.
Unterschiede:
Grundsätzlich gibt es keinen Unterschied in der Verwendung zwischen Methodenplan und Methode ScheduleAtFixedRate, das heißt, ScheduleAtFixedRate hat eine Nachholausführung. Das heißt, wenn eine Aufgabe während der periodischen Ausführung unterbrochen wird, versucht ScheduleAtFixedRate, die zuvor fallengelassenen Aufgaben auszugleichen. Ignorieren Sie den Zeitplan und führen Sie einfach die nächste Aufgabe aus. Sie können auf diesen Blog verweisen, der sehr anschaulich ist.
Der obige Inhalt zeigt, wie man den Java-Timer verwendet. Ich hoffe, er kann jedem helfen.
Verwandte Empfehlungen:
C#-Timer-Timer-Beispieleinführung
Detaillierte Erläuterung der Verwendung von Timer in C# und Lösung des Wiedereintrittsproblems
Detaillierte Erläuterung des Java-Timers (Timer, TimerTask) und Beispielcode
Das obige ist der detaillierte Inhalt vonSo verwenden Sie den Java-Timer Timer. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!