Methode Arrays.sort(Object[] arr)

Status
Nicht offen für weitere Antworten.
I

igor99

Gast
Hallo allerseits!

Die Methode public static void sort(Object[] a) aus der Klasse java.util.Arrays sortiert das übergebene Array von Objekten. Dazu ist allerdings nötig, dass die natürliche Sortierordnung definiert ist (die Mutterklasse von Objekten im Array muss die Schnittstelle Comparable implementieren). Meine Frage ist: Wieso hat man den Datentyp Object[] genommen? Wäre Comparable[] nicht sinnvoller gewesen? Gibt es dafür nachvollziebare Gründe?

Danke
 

Tobias

Top Contributor
Ich vermute eine Nachlässigkeit (Unachtsamkeit) des Programmierers als Ursache. Eine Methode, die nur mit Comparable funktioniert, braucht keine Objects annehmen...

mpG
Tobias
 

sliwalker

Top Contributor
Hi,

Comparable ist nur ein Interface und keine Klasse.
Object ist eine Klasse, von der alle anderen (zumindest alle nicht primitiven) Datentypen erben.
Sprich alles ist kompatibel zu Object. So kann man sich leicht aus dem Object wieder den Typ casten den man braucht.

greetz
SLi
 
G

Guest

Gast
sliwalker hat gesagt.:
So kann man sich leicht aus dem Object wieder den Typ casten den man braucht.

Ich habe die Implementierung angeschaut und habe keine Codezeile gefunden, welche mit Comparable nicht funktionieren würde.

Methode
Code:
public static void sort(Object[] a) {
        Object[] aux = (Object[])a.clone();
        mergeSort(aux, a, 0, a.length, 0);
    }

kann durch die Methode
Code:
public static void sort(Comparable[] a) {
        Object[] aux = (Object[])a.clone();
        mergeSort(aux, a, 0, a.length, 0);
    }

ersetzt werden. Auch die Methode mergeSort würde mit Comparable funktionieren (wenigstens nach der Meinung des Compilers, denn ausgeführt habe ich es nicht).

Habe ich da etwas übersehen? Oder, handelt es sich tatsächlich um die Nachlässigkeit des Programmierers?

Danke
 
B

bygones

Gast
scheint echt ein fehler der programmierer zu sein. Im sortiercode wird dann jedes Object zu einem Comparable gecastet. Wären die Objekte nicht vom Typ Comparable, so fliegt die methode logischerweise einem um die ohren....

Logischer wäre tatsächlich von anfang an Comparable zu verlangen !
 
R

Roar

Gast
und was ist wenn man als programmierer nur Objects zur verfügung hat, woher auch immer? ob man im eigenen code zu Comparable castet oder sort() das machen lässt kommt ja das gleiche raus, und letzteres is doch angenehmer...
 
B

bygones

Gast
aber es ist nicht sicher... würde die Methode Comparable verlangen, kann man sich sicher sein, dass auch sortiert wird... für mich stellt das einfach ein risiko da...
 

sliwalker

Top Contributor
deathbyaclown hat gesagt.:
aber es ist nicht sicher... würde die Methode Comparable verlangen, kann man sich sicher sein, dass auch sortiert wird... für mich stellt das einfach ein risiko da...

Seh ich anders. Denn schließlich

igor99 hat gesagt.:
Die Methode public static void sort(Object[] a) aus der Klasse java.util.Arrays sortiert das übergebene Array von Objekten. Dazu ist allerdings nötig, dass die natürliche Sortierordnung definiert ist (die Mutterklasse von Objekten im Array muss die Schnittstelle Comparable implementieren).

und deshalb kann man sich sicher sein. Darum unterstütz ich Roars Ansicht.

greetz
SLi
 
B

bygones

Gast
nein - falsch !

da Object verlangt wird kann man ohne Probleme eine beliebige Klasse reinstecken, die rein gar nix mit Comparable zu tun hat. Folge ist, die MEthode fliegt einem um die Ohren.

Würde die Methode sort gleich ein COmparable[] verlangen, so könnte ich gar nicht meine beliebige Klasse reinstecken und wäre somit sicher, dass die Methode erflogreich zu ende läuft

dein zitat widerspricht mir auch nicht im geringsten
(die Mutterklasse von Objekten im Array muss die Schnittstelle Comparable implementieren).
genau - die Objekte im Array MÜSSEN Comparable implementieren, damit es läuft - also warum nicht gleich in der Methode so festlegen ?!
 

sliwalker

Top Contributor
Hi,

ich will Dir gern glauben, wenn ich es verstanden habe.
Dazu müsste ich aber noch folgendes loswerden:

sort() verlangt ein Array vom Typ Object.
Ich habe es jetzt so verstanden, dass das Array ruhig vom Typ Object sein kann, das ist ja völlig wurscht. Nur die einzelnen Elemente, die ja auch vom Typ Object sind, müssen von einer Klasse abgeleitet sein, die Comparable implementiert. Damit haben die Objekte im Array auch alle den Typ Comparable.
So ist es doch wenn man Interfaces implementiert!?

Jetzt weiß ich nicht genau, ob damit gleichzeitig auch das gesamte Array vom Typ Comparable ist. Aber ich sehe nicht, warum Du meinst, dass man was x-beliebiges reinpacken kann.

greetz
SLi
 
B

bygones

Gast
der Array ist immer vom Typ seiner Elemente, d.h. Comparable[] ist ein Array von Comparable elementen.

Stell dir vor du hast folgende Klasse:
Code:
public class MyClass {
  private String name;
  private int number;
  private List<String> content;
 

 //... irgendwelche Methoden
}
das ist nun meine xbeliebige Klasse, diese Klasse ist auch automatisch Object, d.h. ich kann mit dieser Klasse die sort Methode aufrufen
Code:
MyClass[] derArray = ....;
Arrays.sort(derArray);
der compiler meckert nicht, da er laut deklaration ein Object[] verlangt... die Methode fliegt mir aber um die Ohren, da MyClass nicht das Interface Comparable implementiert und somit der cast nach Comparable in der Methode sort nicht klappt.

Würde die Definition von sort explizit Comparable[] verlangen (klar, bei der mit einem Comparator ist dies obsolet), so würde schon der Compiler bei dem Aufruf oben meckern....
 

Bleiglanz

Gesperrter Benutzer
Würde die Definition von sort explizit Comparable[] verlangen (klar, bei der mit einem Comparator ist dies obsolet), so würde schon der Compiler bei dem Aufruf oben meckern...
In den meisten Fällen kommt das Array doch als irgendwas anderes daher, sagen wir
Code:
Person[]  personen;
und den dann fälligen Cast
Code:
Comparable[] foo = (Comparable[]) personen;
prüft der Compiler eh nicht elementweise, es würde also nur eine Zeile mehr Code erfordern der keinerlei Vorteile für die Typsicherheit bringt

vielleicht ham die auch das irgendwann mal übersehen, aber als teil der API kann man das jetzt nicht mehr ändern ohne exisiterenden Code ungültig zu machen
 
B

bygones

Gast
wenn die Methode sort einen Comparable[] als Parameter definieren würde, so bräuchte man in der methode überhaupt keinen cast. In der Methode wird nicht der array gecastet, sondern jedes element.

Durch das ändern würde man doch keinen existierenden Code ungütlig machen ?! es geht doch nur darum, das entsprechende Interface zu nehmen ....
 

Bleiglanz

Gesperrter Benutzer
"in" der Methode nicht, aber draussen? in
Code:
sort(Comparable[] arr)
könnte man doch (ohne cast) kein Object[] reinstecken?
 
B

bygones

Gast
klar, aber was für einen sinn macht es einen Object[] reinzustecken ? ich benötige zum sortieren eine definierte Ordnung, die ich bei einem Object[] möglicherweise gar nicht habe,.....
 

Bleiglanz

Gesperrter Benutzer
ja, es wäre sinnvoll wenn man "die Clients" zwingen würde, vor jedem Aufruf von sort(..) den cast
Code:
Comparable[] foo = (Comparable[]) personen;
explizit durchzuführen.

Aber der Compiler prüft ja an der Stelle gar nicht, ob Person das Interface überhaupt implementiert, von daher ist das IMHO von beschränktem Nutzen - auch wenns aus "Hygienegründen" schon so gemacht werden sollte :)
 

Illuvatar

Top Contributor
Wie Bleiglanz sagte, wegen der Abwärtskompatibilität kann man das nicht mehr einfach ändern. Aber es wäre ja dennoch möglich, zusätzlich eine Methode sort(Comparable[]) einzubauen, und die alte deprecated zu machen.

Btw: Sun-Leute, lest den Thread hier :D
 
B

bygones

Gast
wenn ich die Klasse Person habe, die das Interface implementiert, so kann ich, wenn die Methodendefinition Comparable vorsieht, mein Person[] ohne Probleme übergeben. Würde sie es nicht tun, so müsste der Compiler meckern, wenn ich einfach Person[] übergebe....

daher ist doch ein cast unnötig, wenn meine Klasse das interface implementiert....

mhm - oder meckert da nicht der compiler sondern nur eclipse ?!
 

Bleiglanz

Gesperrter Benutzer
tatsächlich...es muss sich wohl um Faulheit handeln

die andere Sort-Methode
Code:
    public static <T> void sort(T[] a, Comparator<? super T> c) {
	T[] aux = (T[])a.clone();
        if (c==null)
            mergeSort(aux, a, 0, a.length, 0); // hier casten?
        else
            mergeSort(aux, a, 0, a.length, 0, c);
    }
delegiert nämlich einfach, wenn der Comparator null ist

und genau an der Stelle wäre der erzwungene cast ungeprüft, aber trotzdem: der Aufrufer würde die ohnehin fliegende Exception nur früher bekommen

offensichtlich ein echter Design-Fehler...?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Fehler bei Arrays.sort(array) - Methode!? Java Basics - Anfänger-Themen 3
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
M Die Inhalte eines Arrays mit der Methode Arrays.toString ausgeben Java Basics - Anfänger-Themen 4
O Arrays sortieren in einer Methode Java Basics - Anfänger-Themen 2
L Probleme bei Rückgabe eines Arrays in einer Methode Java Basics - Anfänger-Themen 47
F Arrays "Count()" Methode Java Basics - Anfänger-Themen 5
S Datentypen Mit einer Methode String arrays geben Java Basics - Anfänger-Themen 9
V Arrays aus eigener Klasse erstellt, zuweisung aber spuckt Fehler in verbindung mit main Methode aus. Java Basics - Anfänger-Themen 3
R Methode zum Einlesen von int-Arrays Java Basics - Anfänger-Themen 6
B Methode zum kopieren von Arrays Java Basics - Anfänger-Themen 9
kae add Methode für Arrays Java Basics - Anfänger-Themen 12
F Arrays in Methode übergeben Java Basics - Anfänger-Themen 11
U Methode Vergleich von 2 Arrays Java Basics - Anfänger-Themen 5
R Einer Methode mit Arrays Werte übergeben Java Basics - Anfänger-Themen 6
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
til237 Iterative Methode in rekursive Methode umschreiben Java Basics - Anfänger-Themen 4
M Daten aus errechneter Methode in Datenbank(SQLite) schreiben Java Basics - Anfänger-Themen 60
D next() Methode mehrfach verwenden Java Basics - Anfänger-Themen 1
Ostkreuz Methoden Von Dezimal zu Hexadezimal Methode toHex Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
N Throw an Main Methode übergeben Java Basics - Anfänger-Themen 7
M Methoden Methode 'wiederhole' nicht gefunden (Uebersetzungsfehler) Java Basics - Anfänger-Themen 1
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
M Anzahl Kommandozeilenparamter mittels Methode Java Basics - Anfänger-Themen 11
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
J Die statische Main-Methode ändert Instanzvariable? Java Basics - Anfänger-Themen 10
D Methode aus dem Aufrufer aufrufen Java Basics - Anfänger-Themen 1
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
U Beispiel Methode size() vom "Collection"-interface... Wie kann man sichtbar machen, was die Methode unter der Haube macht? Java Basics - Anfänger-Themen 8
D Warum kann ich hier nicht auf die Methode zugreifen? Java Basics - Anfänger-Themen 5
M generate Methode für Streams Java Basics - Anfänger-Themen 6
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
I Optionaler Parameter bei Methode, der nur optional ist? Java Basics - Anfänger-Themen 6
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
T Linked List set-Methode Java Basics - Anfänger-Themen 2
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
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
W Equals-Methode überschreiben bei composition Java Basics - Anfänger-Themen 20
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
V Methoden printChar Methode mit Rückgabetyp void Java Basics - Anfänger-Themen 26
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
berserkerdq2 wie funktioniert contenthandler, was muss ich bei der Methode startElement und endElement tun? Java Basics - Anfänger-Themen 11
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
S Methode Java Basics - Anfänger-Themen 4
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
Liroyd Methode mit Objektvariabel rechnen? Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
D Methode um mögliche Rezepte auszugeben Java Basics - Anfänger-Themen 12
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
J Hallo zusammen , was macht diese Methode hier genau? Java Basics - Anfänger-Themen 3
D Array in Main Methode aus anderer Klasse aufrufen Java Basics - Anfänger-Themen 3
H Eine Methode über Actionlistener beenden Java Basics - Anfänger-Themen 8
G jButton führt Main Methode nicht richtig aus Java Basics - Anfänger-Themen 3
G Main Methode wird beim ersten Aufruf nicht richtig ausgeführt Java Basics - Anfänger-Themen 1
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
L Iteratorform und Methode mit variabler Parameterzahl Java Basics - Anfänger-Themen 31
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben