Rheinwerk Computing < openbook > Rheinwerk Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.
 
Inhaltsverzeichnis
Vorwort
1 Neues in Java 8 und Java 7
2 Fortgeschrittene String-Verarbeitung
3 Threads und nebenläufige Programmierung
4 Datenstrukturen und Algorithmen
5 Raum und Zeit
6 Dateien, Verzeichnisse und Dateizugriffe
7 Datenströme
8 Die eXtensible Markup Language (XML)
9 Dateiformate
10 Grafische Oberflächen mit Swing
11 Grafikprogrammierung
12 JavaFX
13 Netzwerkprogrammierung
14 Verteilte Programmierung mit RMI
15 RESTful und SOAP-Web-Services
16 Technologien für die Infrastruktur
17 Typen, Reflection und Annotationen
18 Dynamische Übersetzung und Skriptsprachen
19 Logging und Monitoring
20 Sicherheitskonzepte
21 Datenbankmanagement mit JDBC
22 Java Native Interface (JNI)
23 Dienstprogramme für die Java-Umgebung
Stichwortverzeichnis

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java SE 8 Standard-Bibliothek von Christian Ullenboom
Das Handbuch für Java-Entwickler
Buch: Java SE 8 Standard-Bibliothek

Java SE 8 Standard-Bibliothek
Pfeil 5 Raum und Zeit
Pfeil 5.1 Weltzeit *
Pfeil 5.2 Wichtige Datum-Klassen im Überblick
Pfeil 5.2.1 Der 1.1.1970
Pfeil 5.2.2 System.currentTimeMillis()
Pfeil 5.2.3 Einfache Zeitumrechnungen durch TimeUnit
Pfeil 5.3 Sprachen der Länder
Pfeil 5.3.1 Sprachen und Regionen über Locale-Objekte
Pfeil 5.4 Internationalisierung und Lokalisierung
Pfeil 5.4.1 ResourceBundle-Objekte und Ressource-Dateien
Pfeil 5.4.2 Ressource-Dateien zur Lokalisierung
Pfeil 5.4.3 Die Klasse ResourceBundle
Pfeil 5.4.4 Ladestrategie für ResourceBundle-Objekte
Pfeil 5.4.5 Ladeprozess und Format anpassen *
Pfeil 5.5 Die Klasse Date
Pfeil 5.5.1 Objekte erzeugen und Methoden nutzen
Pfeil 5.5.2 Date-Objekte sind nicht immutable
Pfeil 5.6 Calendar und GregorianCalendar
Pfeil 5.6.1 Die abstrakte Klasse Calendar
Pfeil 5.6.2 Calendar nach Date und Millisekunden fragen
Pfeil 5.6.3 Abfragen und Setzen von Datumselementen über Feldbezeichner
Pfeil 5.6.4 Kalender-Typen *
Pfeil 5.6.5 Kalender-Exemplare bauen über den Calendar.Builder
Pfeil 5.6.6 Wie viele Tage hat der Monat, oder wie viele Monate hat ein Jahr? *
Pfeil 5.6.7 Wann beginnt die Woche und wann die erste Woche im Jahr? *
Pfeil 5.6.8 Der gregorianische Kalender
Pfeil 5.7 Zeitzonen in Java *
Pfeil 5.7.1 Zeitzonen durch die Klasse TimeZone repräsentieren
Pfeil 5.7.2 SimpleTimeZone
Pfeil 5.7.3 Methoden von TimeZone
Pfeil 5.9 Formatieren und Parsen von Datumsangaben
Pfeil 5.9.1 Ausgaben mit printf(…)
Pfeil 5.9.2 Ausgaben mit Calendar-Methoden getDisplayName(…) *
Pfeil 5.9.3 Mit DateFormat und SimpleDateFormat formatieren
Pfeil 5.9.4 Parsen von Datumswerten
Pfeil 5.10 Date-Time-API in Java 8
Pfeil 5.10.1 Datumsklasse LocalDate
Pfeil 5.10.2 Ostertage *
Pfeil 5.10.3 Die Klasse YearMonth
Pfeil 5.10.4 Die Klasse MonthDay
Pfeil 5.10.5 Aufzählung DayOfWeek und Month
Pfeil 5.10.6 Klasse LocalTime
Pfeil 5.10.7 Klasse LocalDateTime
Pfeil 5.10.8 Klasse Year
Pfeil 5.10.9 Zeitzonen-Klassen ZoneId und ZoneOffset
Pfeil 5.10.10 Temporale Klassen mit Zeitzoneninformationen
Pfeil 5.10.11 Klassen Period und Duration
Pfeil 5.10.12 Klasse Instant
Pfeil 5.10.13 Parsen und Formatieren von Datumszeitwerten
Pfeil 5.10.14 Das Paket java.time.temporal *
Pfeil 5.10.15 Konvertierungen zwischen der klassischen API und Date-Time-API
Pfeil 5.11 Die Default-Falle
Pfeil 5.12 Zum Weiterlesen
 
Zum Seitenanfang

5.5Die Klasse Date Zur vorigen ÜberschriftZur nächsten Überschrift

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. Date-Objekte sind mutable, also veränderbar. Sie lassen sich daher nur mit Vorsicht an Methoden übergeben oder zurückgeben.

Im SQL-Paket gibt es eine Unterklasse von java.util.Date, die Klasse java.sql.Date. Bis auf eine statische Methode java.sql.Date.valueOf(String), die Zeichenfolgen mit dem Aufbau »yyyy-mm-dd« erkennt, gibt es keine Unterschiede.

 
Zum Seitenanfang

5.5.1Objekte erzeugen und Methoden nutzen Zur vorigen ÜberschriftZur nächsten Überschrift

Viele Methoden von Date sind veraltet, und zwei Konstruktoren der Klasse bleiben uns:

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 mit 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.

[zB]Beispiel

Mit der toString()-Methode können wir ein minimales Zeitanzeige-Programm schreiben. Wir rufen den Standard-Konstruktor auf und geben dann die Zeit aus. Die println(…)-Methode ruft wie üblich automatisch toString() auf:

Listing 5.8com/tutego/insel/date/MiniClock.java

package com.tutego.insel.date;

class MiniClock {
public static void main( String[] args ) {
System.out.println( new java.util.Date() ); // Fri Jun 08 18:58:21 CEST 2012
}
}

Die anderen Methoden erlauben Zeitvergleiche und operieren auf den Millisekunden.

class java.util.Date
implements Serializable, Cloneable, Comparable<Date>
  • long getTime()
    Liefert die Anzahl der Millisekunden nach dem 1. Januar 1970, 00:00:00 GMT zurück. Der Wert ist negativ, wenn der Zeitpunkt vor dem 1.1.1970 liegt.

  • void setTime(long time)
    Setzt wie der Konstruktor die Anzahl der Millisekunden des Datum-Objekts neu.

  • boolean before(Date when)

  • boolean after(Date when)
    Testet, ob das eigene Datum vor oder nach dem übergebenen Datum liegt: Gibt true zurück, wenn when vor oder nach dem eigenen Datum liegt, 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 Datumsobjekte auf Gleichheit. Gibt true zurück, wenn getTime() für den eigenen Zeitwert und das Datumsobjekt hinter obj den gleichen Wert ergibt und der aktuelle Parameter nicht null ist.

  • int compareTo(Date anotherDate)
    Vergleicht zwei Datum-Objekte und gibt 0 zurück, falls beide die gleiche Zeit repräsentieren. Der Rückgabewert ist kleiner 0, falls das Datum des aufrufenden Exemplars vor dem Datum von anotherDate ist, sonst größer 0.

  • int compareTo(Object o)
    Ist das übergebene Objekt vom Typ Date, dann verhält sich die Methode wie compareTo(…). Andernfalls löst die Methode eine ClassCastException aus. Die Methode ist eine Vorgabe aus der Schnittstelle Comparable. Mit der Methode 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.

 
Zum Seitenanfang

5.5.2Date-Objekte sind nicht immutable Zur vorigen ÜberschriftZur nächsten Überschrift

Dass Date-Objekte nicht immutable sind, ist sicherlich aus heutiger Sicht eine große Designschwäche. Immer dann, wenn Date-Objekte übergeben und zurückgegeben werden sollen, ist eine Kopie des Zustands das Beste, damit nicht später plötzlich ein verteiltes Date-Objekt ungewünschte Änderungen an den verschiedensten Stellen provoziert. Am besten sieht es also so aus:

Listing 5.9com.tutego.insel.date.Person.java, Person

class Person {

private Date birthday;

public void setBirthday( Date birthday ) {
this.birthday = new Date( birthday.getTime() );
}

public Date getBirthday() {
return new Date( birthday.getTime() );
}
}

[»]Hinweis

Eigentlich hat Sun die verändernden Methoden wie setHours(…) oder setMinutes(…)für deprecated erklärt. Allerdings blieb eine Methode außen vor: setTime(long), die die Anzahl der Millisekunden seit dem 1.1.1970 neu setzt. In Programmen sollte diese zustandsverändernde Methode vorsichtig eingesetzt und stattdessen die Millisekunden im Konstruktor für ein neues Date-Objekt übergeben werden.

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Java SE 8 Standard-Bibliothek Java SE 8 Standard-Bibliothek
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Java ist auch eine Insel
Java ist auch eine Insel


Zum Rheinwerk-Shop: Professionell entwickeln mit Java EE 8
Professionell entwickeln mit Java EE 8


Zum Rheinwerk-Shop: Besser coden
Besser coden


Zum Rheinwerk-Shop: Entwurfsmuster
Entwurfsmuster


Zum Rheinwerk-Shop: IT-Projektmanagement
IT-Projektmanagement


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2018
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern