10.6 Die Klasse Date
 
Die ältere Klasse java.util.Date ist durch die Aufgabenverteilung auf die Klassen DateFormat und Calendar sehr schlank. Ein Exemplar der Klasse Date verwaltet ein besonderes Datum oder eine bestimmte Zeit; die Zeitgenauigkeit beträgt eine Millisekunde.
Im SQL-Paket gibt es eine Unterklasse von java.util.Date, die Klasse java.sql.Date. Bis auf eine Fabrikfunktion java.sql.Date.valueOf(String), die Zeichenfolgen mit dem Aufbau »yyyy-mm-dd« erkennt, gibt es keine Unterschiede.
10.6.1 Objekte erzeugen und Methoden nutzen
 
Viele Methoden von Date sind veraltet, und zwei Konstruktoren der Klasse bleiben uns.
Beispiel Mit der toString()-Funktion können wir ein minimales Zeitanzeige-Programm schreiben. Wir rufen den Standard-Konstruktor auf und geben dann die Zeit aus. Natürlich wird von der println()-Funktion toString() aufgerufen.
Listing 10.5
MiniClock.java
class MiniClock
{
public static void main( String[] args )
{
System.out.println( new java.util.Date() ); // Thu Jul 07 18:40:07 CEST 2005
}
}
|
Die anderen Methoden erlauben Zeitvergleiche und operieren auf den Millisekunden.
class java.util. Date
implements Serializable, Cloneable, Comparable<Date>
|
|
Date()
Erzeugt ein Datum-Objekt und initialisiert es mit der Zeit, die bei der Erzeugung gelesen wurde. Die gegenwärtige Zeit erfragt dieser Konstruktor mittels System.currentTimeMillis(). |
|
Date( long date )
Erzeugt ein Datum-Objekt und initialisiert es mit der übergebenen Anzahl von Millisekunden seit dem 1. Januar 1970, 00:00:00 GMT.1
|
|
long getTime()
Liefert die Anzahl der Millisekunden nach dem 1. Januar 1970, 00:00:00 GMT zurück. |
|
void setTime( long time )
Setzt wie der Konstruktor die Anzahl Millisekunden des Datum-Objekts neu. Wurde ein Datum-Objekt einmal erzeugt, dann ändert sich das durch das Objekt repräsentierte Datum natürlich nicht mehr automatisch. Um also die Zeit wieder aktuell zu setzen, kann today.setTime( new java.util.Date() ) verwendet werden. |
|
boolean before( Date when ) |
|
boolean after( Date when )
Testet, ob das eigene Datum vor oder nach dem übergebenen Datum liegt: true, wenn davor oder danach, sonst false. Falls die Millisekunden in long bekannt sind, kommt ein Vergleich mit den primitiven Werten zum gleichen Ergebnis. |
|
boolean equals( Object obj )
Testet die Datums-Objekte auf Gleichheit. true, wenn getTime() für beide den gleichen Wert ergibt und der aktuelle Parameter nicht null ist. |
|
int compareTo( Date anotherDate )
Vergleicht zwei Datum-Objekte und gibt null zurück, falls beide die gleiche Zeit repräsentieren. Der Rückgabewert ist kleiner null, falls das Datum des aufrufenden Exemplars vor dem Datum von anotherDate ist, sonst größer null. |
|
int compareTo( Object o )
Ist das übergebene Objekt vom Typ Date, dann verhält sich die Funktion wie compareTo(). Andernfalls wirft die Methode eine ClassCastException. Die Methode ist eine Vorgabe aus der Schnittstelle Comparable. Mit der Funktion lassen sich Date-Objekte in einem Feld über Arrays.sort(Object[]) oder Collections.sort() einfach sortieren. |
|
String toString()
Gibt eine Repräsentation des Datums aus. Das Format ist nicht landesspezifisch. |
1 Bei Visual Basic steht der Wert 0 für den 30.12.1899. Super Idee! Excel beginnt einen Tag später, beim 1.1.1900.
|