Klasse Toolkit?

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
Hallo,

in der Java-Insel steht:

"Die abstrakte Klasse Toolkit abstrahiert von system- und bildschirmabhängigen Implementierungen."

Das verstehe ich nicht ganz. Was sind Beispiele für System- und Bildschirmabhängige Implementierungen? Und wozu muss man sich mittels getDefaultToolkit das entsprechenden Toolkit des Betriebssystems zurückgeben lassen?

Warum wurde es nicht so gelöst, dass man einfach eine normale Klasse Toolkit erzeugen müsste, die intern dann auf Betriebssystem spezifische Dinge "umleitet",

also statt Toolkit.getDefaultToolkit ein

Toolkit.getScreenDimension oder so und das liefert dann unter Windows/Linux usw. dann auch die entsprechenden Werte... Warum also der Umweg über die get Methode. Was ist der Vorteil das über eine getMethode zu lösen?

Fragen über Fragen :)
 
S

SlaterB

Gast
die unterschiedlichen Implementierungen erfordern auf jeden Fall spezielle Klassen,
also ist ein Interface bzw. eine abstrakte Oberklasse mit Auflistung aller Methoden auf jeden Fall notwendig,

auf jeden Fall wird auch ein Objekt dieser speziellen Klasse benötigt,

nun kann man entweder genau 5 Zeilen Code schreiben, die dieses Objekt zurückgeben und alles ist fertig und einsatzbereit,
oder man definiert für 30 Methoden jeweils 5 Zeilen Code einer statischen Methode, die an das Toolkit-Objekt delegiert,
wozu?
damit du den getDefaultToolkit()-Aufruf sparst? ;)

da Objekte eh viel objektorientierter sind, macht das keinen rechten Sinn,
außerdem verschenkt man dadurch die Möglichkeiten der Vererbung, einer eigenen Unterklasse von Toolkit

wenn du möchstest, kannst du dir aber selber eine Klasse mit statischen Methoden schreiben, die unsichtbar an das DefaultToolkit weiterleiten
 
G

Gast

Gast
Hallo Christian,

ok, danke für die Antwort.

Wie meinst du aber das:

>nun kann man entweder genau 5 Zeilen Code schreiben, die >dieses Objekt zurückgeben und alles ist fertig und einsatzbereit,
>oder man definiert für 30 Methoden jeweils 5 Zeilen Code
 
S

SlaterB

Gast
das Toolkit-Objekt kann man bereist nach isDynamicLayoutActive() fragen oder was immer man es fragen möchte,

damit das auch statisch geht, müsste man eine Methode

public static boolean isDynamicLayoutActive() {
// test ob DefaultToolkit schon vorhanden, evtl. erst initialisieren
return Klasse.staticToolkit.isDynamicLayoutActive();
}

schreiben, dieser Aufwand für jede Methode einzeln


edit: kürzer wäre sicherlich

public static boolean isDynamicLayoutActive() {
return getDefaultToolKit().isDynamicLayoutActive();
}

dennoch zusätzlicher unschöner Aufwand
 
G

Gast

Gast
Hallo,

das habe ich jetzt irgendwie nicht verstanden :-( Es ging doch um das zurückgeben des Objektes. Das dadurch weniger Schreibaufwand nötig ist. Kannst du es bitte nochmal erklären.

Danke schön
 
S

SlaterB

Gast
durch das Zurückgeben des Objektes spart man sich die statischen Methoden, mann muss sie einfach nicht schreiben, kann sie gedanklich wegradieren,
das ist 'weniger Schreibaufwand' ;)
 
S

SlaterB

Gast
nötig sind sie nicht, das stand nur in deinem ersten Posting,
frei neu zusammengesetzt:
'warum nicht eine statische Methode Toolkit.getScreenDimension() statt Toolkit.getDefaultToolkit().getScreenDimension()?'
 

slawaweis

Bekanntes Mitglied
Anonymous hat gesagt.:
"Die abstrakte Klasse Toolkit abstrahiert von system- und bildschirmabhängigen Implementierungen."
in dem Buch wurde es unglücklich ausgedruckt, was vor allem Anfänger verwirrt. Toolkit ist im Grunde eine abstrakte Schnittstelle zu bestimmten betriebssystemabhängigen Eigenschaften oder Funktionen. Weiterhin ist diese Schnittstelle universell, d.h. man muss nicht wissen, auf welchen OS gerade das Programm läuft. Die drunterliegende Implementierung der JVM mappt dann die Aufrufe oder Anforderungen des Toolkits auf die OS Implementierung.

Anonymous hat gesagt.:
Das verstehe ich nicht ganz. Was sind Beispiele für System- und Bildschirmabhängige Implementierungen? Und wozu muss man sich mittels getDefaultToolkit das entsprechenden Toolkit des Betriebssystems zurückgeben lassen?
für die erste Frage muss man sich einwenig mit Betriebssystemen beschäftigen. Wenn man überwiegend nur Windows kennt, kennt man quasi nur einen Desktop. Doch auf anderen System gibt es mehrere Desktop Implementierungen (z.B. Gnome, KDE) oder GUI-Systeme, die komplett ohne Fenster auskommen (z.B. an Supermarktkassen oft zu beobachten). Für jede dieser Varianten eines Desktops gibt es eigene Toolkit Klassen in der Implementierung der JVM. Man kann es sich so vorstellen (der folgende Code ist rein fiktiv):

Code:
 private static Toolkit default_toolkit = null;

 // …

 public static Toolkit getDefaultToolkit()
  {
  if(default_toolkit == null)
    {
    if(os_desktop.equals("gnome"))
      default_toolkit = new GnomeToolkit();
    else if(os_desktop.equals("kde"))
      default_toolkit = new KDEToolkit();
    }
  return default_toolkit;
  }

Deine zweite Frage kann man folgend beantworten: war eine Designentscheidung. Man hätte es so oder so lösen können, also entweder mit getDefaultToolkit() oder direkt über statische Funktionen. Doch vor allem bei der zweiten Variante würde man immer noch eine weitere Klasse brauchen, die eben die ganzen Funktionen wieder als abstrakt definiert, damit davon die verschiedenen Implementierungen abgeleitet werden können. D.h. am Ende gäbe es 2 ähnliche Klassen, eine mit abstrakten und eine mit statischen Funktionen.

Ein Problem mit Toolkit.getDefaultToolkit() sehe ich übrigens nicht. Bei der Komplexität der heutigen Programme ist so was egal. Außerdem kann man so vorgehen, wenn man Toolkit länger verwenden möchte:

Code:
 Toolkit toolkit = Toolkit.getDefaultToolkit();

 toolkit.get...
 toolkit.get...
 toolkit.get...
 toolkit.get...

Ein weiterer Vorteil von Toolkit.getDefaultToolkit() ergibt sich, wenn man eigene Desktops implementieren will. Theoretisch kann man in Java einen kompletten Desktop schreiben, der den nativen überlagert. Dafür könnte man dann eine eigene Toolkit Klasse ableiten.

Slawa
 
G

Gast

Gast
Hallo,

danke für eure Antworten... OK, getDefaultToolkit liefert dann eine entsprechende Implementierung zurück. Soweit verstanden. Ich meinte aber wieso man nicht einfach

Toolkit t = new Toolkit() schreiben könnte und die Klasse ermittelt dann selbst wie die entsprechende Implementierung aussieht ala

public Toolkit()
{
if(Betriebssystem==Windows) Instanz ist Windows Toolkit
if(Betriebssystem==Linux) Instanz ist Linux Toolkit
}

die Methode getDefaultToolkit macht doch im Grunde nix anderes...
 

Schandro

Top Contributor
Das ist ne Factory-Methode. Dadurch wird nicht jedes mal ne neue Instanz von Toolkit erstellt. Ich denke mal, beim erstenAufruf von getDefaultToolkit() wird ne neue Instanz erstellt und zurückgegeben, alle darauf folgenden Aufrufe geben einfach nurnoch ne Referenz auf die bereits erstellte Instanz zurück. Sowas würde nicht gehen, wenn der Benutzer jedesmal den Konstruktor von Toolkit benutzen würde.

EDIT: Ok, hab grad im Quellcode nachgeguckt. Toolkit ist wirklich en Singleton, d.h. er hat ne statische Variable vom eigenen Typ "Toolkit" und solang diese Variable nicht null ist, wird bei getDefaultToolkit() einfach nur diese returnt und nicht ein neues Object erstellt
 

HoaX

Top Contributor
Weil das in Java nicht geht. new BeliebigeKlasse() liefert _immer_ eine Instanz von BeliebigeKlasse, und nie plötzlich eine andere Implementierung.
 

slawaweis

Bekanntes Mitglied
Gast hat gesagt.:
danke für eure Antworten... OK, getDefaultToolkit liefert dann eine entsprechende Implementierung zurück. Soweit verstanden. Ich meinte aber wieso man nicht einfach

Toolkit t = new Toolkit() schreiben könnte und die Klasse ermittelt dann selbst wie die entsprechende Implementierung aussieht ala

public Toolkit()
{
if(Betriebssystem==Windows) Instanz ist Windows Toolkit
if(Betriebssystem==Linux) Instanz ist Linux Toolkit
}

die Methode getDefaultToolkit macht doch im Grunde nix anderes...
dein Model entspricht einem Delegator-Pattern, d.h. eine Klasse macht nicht anderes, als die Funktionsaufrufe an eine andere Klasse weiterzuleiten. Doch in dem Toolkit spielt das Singleton-Pattern eine Rolle, den eine Instanz von Toolkit darf es nur einmal im System geben, und genau das wird mit getDefaultToolkit dem Programmierer klargemacht. Das hat wieder mal was mit dem Betriebssystem zu tun. Wer schon mal Win32, SWT oder allgemein C/C++ programmiert hat, der weis, dass wenn man die benötigten Ressourcen anfordert, man diese irgendwann selber freigeben muss. Toolkit greift auf diese Betriebssystemressourcen zu und hält diese bis zum Ende der JVM. Am Ende, wenn die JVM beendet wird, werden die Ressourcen in der finalize() Methode (hat jedes Object) wieder freigegeben. Würden diese Ressourcen nicht freigegeben, würden die auch nach dem Beenden der JVM noch belegt sein. Das Singleton-Pattern ist jetzt notwendig damit verschiedenen Instanzen von Toolkit nicht die selben Ressourcen mehrfach anfordern. Wenn man z.B. eine Grafik mit getImage(URL url) als Systemressource anfordern, dann wird diese nur einmal als Systemressource angelegt und bei erneuten Aufruf immer wieder zurückgegeben. Ist auch eine Optimierungssache.

Doch im Grunde ist es egal wie es umgesetzt wurde, war eben eine Designentscheidung des AWT-Teams. Ich schreibe öfters größere Swing-Anwendungen, benutze Toolkit aber nur 4-5 Mal pro Projekt. Wer unbedingt Toolkit beliebig instanzieren will, kann ohne Probleme sich einen Delegator schreiben:

Code:
public class MyToolkit extends Toolkit
{
 protected Toolkit toolkit = null;

 public MyToolkit()
  {
  this.toolkit = Toolkit.getDefaultToolkit();
  }

// Implementation aller Toolkit Funktionen als Delegatoren
}

// Benutzung
Toolkit t1 = new MyToolkit();
Toolkit t2 = new MyToolkit();
Toolkit t3 = new MyToolkit();

doch es ändert nichts an der Funktionalität. Das AWT-Team hätte es damals (1996) auch so umsetzen können, allerdings wüsten dann die Programmierer nicht auf Anhieb, ob es ein Singleton-Pattern ist oder ob jedes Toolkit die selben Ressourcen mehrfach belegt. Ist auch eine Art Selbstdokumentation: "Programmierer/in sehe da, ein Singleton!"

Slawa
 

Ebenius

Top Contributor
slawaweis hat gesagt.:
[...] Doch in dem Toolkit spielt das Singleton-Pattern eine Rolle, den eine Instanz von Toolkit darf es nur einmal im System geben, und genau das wird mit getDefaultToolkit dem Programmierer klargemacht.
Ein Singleton ist es nicht. Singleton garantiert maximal eine Instanz. Zitat aus der API-Doc von Component.getToolkit():
Component.getToolkit() hat gesagt.:
Gets the toolkit of this component. Note that the frame that contains a component controls which toolkit is used by that component. Therefore if the component is moved from one frame to another, the toolkit it uses may change.

Ebenius
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
I @Inject in normaler Klasse? Java Basics - Anfänger-Themen 4
P Enum oder normale Klasse? Java Basics - Anfänger-Themen 10
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
P Wie kann ich meine Keylistener Klasse unterscheiden lassen, von welcher "Quelle" der Input kommt? Java Basics - Anfänger-Themen 2
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Amina556 Eigene Klasse definieren Java Basics - Anfänger-Themen 9
berserkerdq2 Intelij, wie kann ich einstellen, dass die aktuelle Klasse ausgeführt wird, wenn ich aufs Startsymbol drücke, gibts da eine Tastenkombination? Java Basics - Anfänger-Themen 11
M Klasse in Runden Klammern bei Objektimplementierung Java Basics - Anfänger-Themen 4
J Klassen Klasse als Komponententyp bei Feldern Java Basics - Anfänger-Themen 2
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
Detlef Bosau nichtstatische Innere Klasse, this Pointer. Java Basics - Anfänger-Themen 47
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
J Zugriff auf eine 2. Klasse die per UI-Designer erstellt wurde Java Basics - Anfänger-Themen 1
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
B Klasse statisch erstellen da n-mal geladen Java Basics - Anfänger-Themen 3
T Meine Klasse wird nicht gefunden Java Basics - Anfänger-Themen 1
XWing Random Punkte erstellen mit der Random klasse Java Basics - Anfänger-Themen 15
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
frager2345 Optional Klasse Java Java Basics - Anfänger-Themen 2
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
H Klassen Typ und Intitialisierungs-Klasse, wer bestimmt was? Java Basics - Anfänger-Themen 1
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
T Thread beenden aus zweiter Klasse Java Basics - Anfänger-Themen 4
frager2345 Java Klasse Buch verwalten Java Basics - Anfänger-Themen 0
frager2345 Java eigen Klasse zum verwalten von Büchern Java Basics - Anfänger-Themen 3
T Zugriff auf Control anderer Klasse Java Basics - Anfänger-Themen 5
H Compiler-Fehler Klasse in einem Package wird nicht gefunden bzw. akzeptiert Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
C Int an andere Klasse übergeben Java Basics - Anfänger-Themen 26
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
B Klasse "Character" Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
U Warum kann ich, auf private Variablen zugreifen, wenn ich ein Objekt in der Klasse, die private Variablen hat erstelle und dort drauf zugreifen will? Java Basics - Anfänger-Themen 7
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
D Array in Main Methode aus anderer Klasse aufrufen Java Basics - Anfänger-Themen 3
I Array Länge in Klasse festlegen Java Basics - Anfänger-Themen 1
L Klassen Vektor Klasse Java Basics - Anfänger-Themen 2
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
M Wie kann ich eine Methode aus einem Interface in eine Klasse implementieren, so dass sie ihre Funktion ausführt? Java Basics - Anfänger-Themen 7
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
W Klasse existiert prüfen Java Basics - Anfänger-Themen 5
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
J Fehler bei array aus anderer Klasse Java Basics - Anfänger-Themen 3
D Einen boolischen Wert aus einer Methode in einer anderen Klasse aufrufen? Java Basics - Anfänger-Themen 11
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
R TreeSet Zugriff aus anderer Klasse Java Basics - Anfänger-Themen 8
C Auf die Methode einer anderen Klasse zugreifen Java Basics - Anfänger-Themen 1
B Static Attribute in einer Klasse, wie geht das? :O Java Basics - Anfänger-Themen 19
M Von einem Menü Methode aus anderer Klasse ausführen, die errechnete Werte in Datei schreibt. Java Basics - Anfänger-Themen 8
KogoroMori21 Objektvariable anderer Klasse übernehmen, Getter/Setter Java Basics - Anfänger-Themen 11
Vivien Auf eine Variable von einer anderen Klasse aus zugreifen Java Basics - Anfänger-Themen 3
M Aufruf von statischen Methoden einer anderen Klasse Java Basics - Anfänger-Themen 15
tony241188 Implementieren Sie die Klasse Hersteller, welche die folgenden Elektrogeräte produziert Java Basics - Anfänger-Themen 3
J Junit4 Klasse erstellen Java Basics - Anfänger-Themen 5
T Auf Instanz der selben Klasse aus überschriebener Methode in Methode zugreifen. Java Basics - Anfänger-Themen 2
M Scanner Klasse Java Basics - Anfänger-Themen 4
L Meine erste eigene Exception Klasse Java Basics - Anfänger-Themen 10
E Warum lässt sich eine Klasse nicht starten, wenn eine andere Klasse in dem Modul fehlerhaft ist? Java Basics - Anfänger-Themen 1
CptK Vererbung Attributtyp in Super-Klasse noch nicht festlegen Java Basics - Anfänger-Themen 1
P Wie rufe ich Methoden mit einer Referenz auf eine Klasse||Objekt auf Java Basics - Anfänger-Themen 4
I JaxB und Klasse "Object" ? Java Basics - Anfänger-Themen 7
H Quellcode Scanner Klasse Java Basics - Anfänger-Themen 2
L Attribute aus Klasse in berechnungs Methode übergeben Java Basics - Anfänger-Themen 1
A Klasse Menge mit Objekten der Klasse Person Java Basics - Anfänger-Themen 8
C Meldung einer Klasse nach "oben" Java Basics - Anfänger-Themen 6
A Methode in einer anderen Klasse verwenden Java Basics - Anfänger-Themen 1
D Attribut Telefonnummer - eigene Klasse oder String Java Basics - Anfänger-Themen 13
N Variable aus anderen Variablen in statischer Klasse berechnen/abspeichern? Java Basics - Anfänger-Themen 4
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
L Datentypen Deklarierte Felder einer Generic Klasse bestimmen Java Basics - Anfänger-Themen 7
C Methoden können nicht auf Instanzvariable der Klasse zugreifen Java Basics - Anfänger-Themen 3
J Scanner-Klasse Java Basics - Anfänger-Themen 2
itsmejo Erste Schritte Auf Attribut einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 14
P NoClassDefFoundError: org/apache/commons/collections4/ListValuedMap trotz vorhandener Klasse? Java Basics - Anfänger-Themen 10
V Array aus Klasse um vererbte Elemente erweitern Java Basics - Anfänger-Themen 3
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
M Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren? Java Basics - Anfänger-Themen 10
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
M Integer aus aus einer Klasse in andere speichern Java Basics - Anfänger-Themen 12
B Objekt von EJB in Controller (CDI) - Klasse füllen? Java Basics - Anfänger-Themen 3
M Java Klasse Object Java Basics - Anfänger-Themen 5
E abstrakte Klasse implementiert ein Interface Java Basics - Anfänger-Themen 40
B Klassen Abstrake Klasse und Template Methode Java Basics - Anfänger-Themen 4
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
B Erste Schritte Guice Injection nicht in jeder Klasse möglich Java Basics - Anfänger-Themen 2
Y Java andere Klasse aufrufen Java Basics - Anfänger-Themen 6
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
G unklares Verhalten nach Instanzierung neuer Klasse Java Basics - Anfänger-Themen 3
Z Matrix Klasse mit Mehrdimensionalen Array (Addition, Multiplikation, to String) Java Basics - Anfänger-Themen 57

Ähnliche Java Themen

Neue Themen


Oben