OOP Methoden überladen - Signatur

knowledge

Bekanntes Mitglied
Hallo,

für das überladen von Methoden wird ja die Signatur (also Name und Parametertyp(en)) herangezogen.

Bsp.

public int add(int a, int b) --> Signatur: add(int, int)
public void add(int a, int b) --> Signatur: add(int,int)

Die Methoden könnten in dem Fall also nicht unterschieden werden. Warum zieht man als Unterscheidungskriterium nicht auch noch den Rückgabetyp hinzu?

Ob die Methode nix (void) oder ein int zurückgibt wäre doch zu unterscheiden, oder nicht? Wieso wird der Rückgabetyp also nicht berücksichtigt?
 

Der Müde Joe

Top Contributor
Den Rückgabetype musst du nicht benutzen. Alle Argumente müssen hingegen vorhanden sein. (Auch wenn sie null sind und das null noch gecastet werden muss)
 

knowledge

Bekanntes Mitglied
Hi,

Danke für die Antwort. Meine Frage ist jedoch WARUM lässt man das nicht zu? Eine Unterscheidung zweier Methoden über den Rückgabetyp wäre doch theoretisch möglich, oder nicht?
 

Der Müde Joe

Top Contributor
>WARUM lässt man das nicht zu?

Welche Methode ruft die main auf:

Java:
public class CrystalMethTest {

	public static void main(String[] args) {
		add(1);
	}

	static void add(int i) {}

	static int add(int i) {return i;}
}
 

knowledge

Bekanntes Mitglied
Hmm, obwohl eine Methode die nen Rückgabewert hat aufzurufen und diesen zu nutzen ist wirklich ein bischen sinnlos. Falls man also ein int in einem Fall und ein void in dem anderen hätte könnte man das schon unterscheiden, aber nur wenn man halt ne Zuweisung macht. Da aber auch der Fall ohne Zuweisung gültig ist wären wir ja wieder beim o.g. Problem, da kann man es ja nicht unterscheiden
 

Wortraum

Bekanntes Mitglied
Das frage ich mich, seitdem es Java gibt. Bei Ada95 gehört der Rückgabewert beispielsweise zur Signatur, und ich finde das fürs Überladen wirklich praktisch. In Java hilft hingegen nur, entweder andere Parameter oder andere Namen zu verwenden. Zwar ist das nicht schön, aber es ist machbar.

Der einzige sinnvolle Grund, der mir einfällt, ist, daß der Bau von Übersetzern vereinfacht wird. So ganz bin ich mit der Antwort jedoch selbst nicht zufrieden.
 

Wuella

Mitglied
Java:
public class CrystalMethTest {
 
    public static void main(String[] args) {
        add(1);
    }
 
    static void add(int i) {}
 
    static int add(int i) {return i;}
}

Würd doch gar nicht gehen, da "duplicate name"
 

faetzminator

Gesperrter Benutzer
Nur weil ich den Rückgabewert nicht benötige (= irgendwo weitergebe), heisst das noch lange nicht, dass ich nicht die Methode mit Rückgabewert int aufrufen will. Es ist sinnvoll, dass dies nicht geht.
 

Antoras

Top Contributor
Java:
public class CrystalMethTest {
 
    public static void main(String[] args) {
        add(1);
    }
 
    static void add(int i) {
        // mach was mit i
    }
 
    static int add(int i) {
        // mach was mit i
        if (fehler) return fehler;
        return keinFehler;
    }
}
In diesem Beispiel wäre es theoretisch möglich, dass beide Methoden aufgerufen werden (wenn der Rückgabewert der Methoden zur Signatur gehören würden). Woher soll der Compiler wissen, welche Methode gemeint ist?
Er könnte es nur dass wissen, wenn man den Rückgabewert einer Methode zwingend verarbeiten müsste, was man aber nicht muss. Er wäre auch Blödsinn, das zu müssen, da ja auch Werte zurückgegeben werden könnten, die u.U. nicht relevant sind - man müsste in dem Fall lauter unnötige Temporärvariablen erzeugen.

Wortraum hat gesagt.:
Der einzige sinnvolle Grund, der mir einfällt, ist, daß der Bau von Übersetzern vereinfacht wird.
Die Syntaxerkennung ist das kleinste Problem beim Bau eines Compilers und da die Rückgabewerte sowieso erkannt werden müssen, ist es nicht mal ein großer Mehraufwand auch noch darauf zu achten welche Methode jetzt aufgerufen wird.
 

knowledge

Bekanntes Mitglied
> da ja auch Werte zurückgegeben werden könnten, die u.U. nicht relevant sind

Warum sollte man aber eine Methode aufrufen die was zurückgibt, wenn der Rückgabewert für mich irrelevant ist? Dann hätte ich mir den Aufruf ja gleich sparen können.
 

Der Müde Joe

Top Contributor
>wenn der Rückgabewert für mich irrelevant ist?

gutes Beispiel:

Collection (Java Platform SE 6)
add(E e)

ArrayList --> immer true (irrelevant)
HasSet --> true, wenn set den wert noch nicht besitzt (evtl von interesse)

EDIT:
aber nach spezifikation:
true if this collection changed as a result of the call
 

Schumi

Bekanntes Mitglied
ooopsie, schlechtes Beispiel gewählt. Besser append() beim StringBuilder.
Wer will schon
Java:
 myStringBuilder =  myStringBuilder.append("bla")
schreiben.
 
Zuletzt bearbeitet:

musiKk

Top Contributor
Warum sollte man aber eine Methode aufrufen die was zurückgibt, wenn der Rückgabewert für mich irrelevant ist? Dann hätte ich mir den Aufruf ja gleich sparen können.

In reinen funktionalen Programmiersprachen wie Haskell wäre diese Aussage korrekt. Dort hat eine Funktion keine Seiteneffekte. In objektorientierten Sprachen ist das aber falsch. Da kann etwas zurückgegeben werden (Beispiele gibts ja schon im Thread) und nebenbei wurde die Festplatte gelöscht. Da kann der Rückgabewert also evtl. auch ignoriert werden.
 

faetzminator

Gesperrter Benutzer
Sorry die Logik erschließt sich mir gerade nicht so ganz, vor allem was dann den letzten Satz betrifft ^^

Sagen wir, folgendes (in diesem Kontext vielleicht nicht gerade logisches) Beispiel:
Java:
public class Test {
    public static void main(String... args) {
        saveValue(8);
    }

    private static double val;

    static int saveValue(int val) {
        Test.val = val * val;
        return (int) Test.val;
    }

    static double saveValue(int val) {
        Test.val = Math.sqrt(val);
        return Test.val;
    }
}
Was soll nun aufgerufen werden? Wie wir wissen kann void gegen etwas anderes als Beispiel ignoriert werden, da ein Rückgabewert nicht verwendet werden muss.
 

Wortraum

Bekanntes Mitglied
Kann nicht kompiliert werden, da die Signatur gleich ist ;)
Um die Frage, warum der Rückgabewert nicht zur Signatur gehört, geht es ja gerade. Wie schon gesagt, ist es schwieriger, einen Übersetzer zu schreiben, und es stellt sich die Frage, ob es eine sinnvolle Funktion ist. Zugegeben, sie ist praktisch, aber sie ist nicht notwendig.

Was passiert, wenn ein Aufruf nicht eindeutig ist, ist in Java natürlich nicht definiert, weil der Rückgabewert dort nicht zur Signatur gehört. Es wäre jedoch kein Problem, Aufrufe, die nicht eindeutig sind, zu verbieten, oder eine Syntax wie double'getValue() einzuführen.

Bei Java entschieden sich die Entwickler dagegen, den Rückgabewert mit in die Signatur zu packen. Es macht die Sprache einfacher. Auch das Überladen von Operatoren ist nicht möglich; es macht die Sprache einfacher. Viel mehr gibt es dazu, denke ich, nicht zu sagen.
 

knowledge

Bekanntes Mitglied
> Keine Seiteneffekte...
>Da kann der Rückgabewert also evtl. auch ignoriert werden.

Ergo, weil ne Methode nicht unbedingt nur ein Ergebnis erzeugt was mich immer interessieren müsste sondern auch noch andere Sachen machen kann, ohne das ich den Rückgabewert brauche, ist es manchmal sinnvoll den Rückgabewert zu ignorieren?

Hmm, in diesem Zusammenhang kann mir evtl. jemand auch nochmal vom müden Joe erklären. Wieso kann ich bei Array den Rückgabewert ignorieren? Seiteneffekt wäre es wird was hinzugefügt? Und boolean sagt mir obs geklappt hat oder nicht. Oder wie seh ich das? Wärs nicht immer interessant zu prüfen ob das add funktioniert hat?
 

faetzminator

Gesperrter Benutzer
Natürlich, man ruft des öfteren Methoden auf, welche etwas zurückgeben, was man nicht benötigt. Zum Beispiel Collection (Java Platform SE 6) oder meist auch http://java.sun.com/javase/6/docs/api/java/lang/Runtime.html#exec%28java.lang.String[]%29. Was willst du in deinem Programm machen, wenn ein [c]add()[/c] nicht funktionierte? Nochmal probieren? Was ist denn schief gegangen?

Edit: Als konkrete Implementation als Beispiel [c]ArrayList.add()[/c]:
Java:
public boolean add(E e) {
    ensureCapacity(size + 1);  // Increments modCount!!
    elementData[size++] = e;
    return true;
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
K OOP Methoden überladen, wo liegt das Problem? Java Basics - Anfänger-Themen 22
N Methoden überladen - loss of precision Java Basics - Anfänger-Themen 2
N Methoden überladen - überschreiben - wo unterschied? Java Basics - Anfänger-Themen 8
emreiu Methoden Rekursive Methoden Runter- & Hochzählen Java Basics - Anfänger-Themen 2
U Funktionale Interfaces mit mehreren abstrakten Methoden? Java Basics - Anfänger-Themen 8
MoxMorris Einige Methoden aus verschiedenen Klassen nacheinander auszuführen läuft seltsam Java Basics - Anfänger-Themen 2
J Argumente in Methoden übergeben Java Basics - Anfänger-Themen 1
XWing Methoden rückgabe Problem? Java Basics - Anfänger-Themen 6
Say Class scope und Instance scope und Getter nur selbstgeschrieben Methoden Java Basics - Anfänger-Themen 11
I Gleiche Klassen und Methoden in unterschiedlichen Projekten nutzen Java Basics - Anfänger-Themen 2
N Klassen Methoden anderer Klassen aufrufen Java Basics - Anfänger-Themen 4
Renjiroo Java Bmi Rechner mit Methoden Java Basics - Anfänger-Themen 4
frager2345 Thread - Methoden synchronized deklarieren Java Basics - Anfänger-Themen 10
M Designentscheidung von Attributen/Methoden im Falle von Vererbung Java Basics - Anfänger-Themen 8
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
Alen123 Erstes Arbeiten mit Methoden. Java Basics - Anfänger-Themen 5
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
M Andere Methoden in anderen Klassen aufrufen Java Basics - Anfänger-Themen 11
L Methoden in anderen Klassen nutzen Java Basics - Anfänger-Themen 6
D Gerade oder ungerade Zahl mittels Methoden Java Basics - Anfänger-Themen 13
M Erklärung von Ausnahmebehandlung in Methoden Java Basics - Anfänger-Themen 13
S Methoden 2 non-static Methoden, trotzdem Fehler "non static method can not be referenced from a static context" Java Basics - Anfänger-Themen 9
L Rekursive Methoden Java Basics - Anfänger-Themen 14
X Wie erreiche ich, dass ein Robot weitere Attribute hat, die nicht materialisiert sind, sondern nur über get/ set-Methoden simuliert sind? Java Basics - Anfänger-Themen 1
C Problem mit mehreren Methoden + Scanner Java Basics - Anfänger-Themen 5
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
W Verschiedene Methoden in einer Klasse in der Main aufrufen? Java Basics - Anfänger-Themen 8
W Methoden aufrufen - auch klassenübergreifend? Java Basics - Anfänger-Themen 9
Kotelettklopfer Methoden nicht aufrufbar Java Basics - Anfänger-Themen 34
R Schulaufgabe, Bruache Hilfe mit non-static Methoden Java Basics - Anfänger-Themen 2
S Vererbung Abstrakte Methoden: Wozu das Ganze?! Java Basics - Anfänger-Themen 7
S abstrakte methoden in subclass? Java Basics - Anfänger-Themen 7
S Methoden - Warum int wenn auch void? Java Basics - Anfänger-Themen 3
H Kann man Methoden öfter aufrufen? Java Basics - Anfänger-Themen 2
CptK Interface Functional interface mit mehreren Methoden Java Basics - Anfänger-Themen 6
P Objekt in mehreren Methoden verwenden. Java Basics - Anfänger-Themen 3
M Aufruf von statischen Methoden einer anderen Klasse Java Basics - Anfänger-Themen 15
lougoldi Verkettung von Methoden und Konstruktoren Java Basics - Anfänger-Themen 4
Zeppi OOP Methoden mit einander Verknüpfen Java Basics - Anfänger-Themen 6
A Löschen von Leerzeichen in einem char array ohne methoden Java Basics - Anfänger-Themen 6
A Parametar übergabe zwischen Methoden Java Basics - Anfänger-Themen 26
D Methoden nach einer bestimmten Reihenfolge ausführen. Java Basics - Anfänger-Themen 20
P Wie rufe ich Methoden mit einer Referenz auf eine Klasse||Objekt auf Java Basics - Anfänger-Themen 4
O Attribute die Methoden zählen Java Basics - Anfänger-Themen 5
M Bräuchte Hilfe bei diesen Methoden Java Basics - Anfänger-Themen 4
G Methoden Methoden mit versch. Datentypen Java Basics - Anfänger-Themen 1
T Ich habe eine Variabel die nicht Methoden übergreifend ist. Kann mir jemand Helfen :) Java Basics - Anfänger-Themen 5
Junger_Basileus Celsius -> Fahrenheit / Strukturierung in statischen Methoden Java Basics - Anfänger-Themen 7
J Verschachtelte Methoden Java Basics - Anfänger-Themen 9
H Methoden in anderen Methoden aufrufen Java Basics - Anfänger-Themen 6
Kawastori Hilfe bei Methoden Übung Java Basics - Anfänger-Themen 6
veryck Methoden Rekursive Methoden mit Rückgabeparameter Java Basics - Anfänger-Themen 9
C Methoden können nicht auf Instanzvariable der Klasse zugreifen Java Basics - Anfänger-Themen 3
P Methoden aufrufen - Fehler Java Basics - Anfänger-Themen 20
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
C eigene Methoden erstellen (Instanzmethoden) Java Basics - Anfänger-Themen 7
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
B Methoden Methoden haben kein Zugriff auf variablen Java Basics - Anfänger-Themen 4
M Gettter/Setter Methoden Klassenfelder kapselung und zugriff? Java Basics - Anfänger-Themen 1
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
C Taschenrechner (switch) in Taschenrechner mit Methoden umwandeln Java Basics - Anfänger-Themen 115
H Methoden in großen Klassen gruppieren oder auslagern? Java Basics - Anfänger-Themen 10
G Generics Methoden Java Basics - Anfänger-Themen 7
L Test-Methoden schreiben Java Basics - Anfänger-Themen 13
S throws bei Methoden Java Basics - Anfänger-Themen 4
L Best Practice Code Refactoring für Methoden mit fast gleicher Aufbau Java Basics - Anfänger-Themen 6
I Greedy Methode Methoden nutzen Java Basics - Anfänger-Themen 3
C Methoden-Parameter ist Interface Java Basics - Anfänger-Themen 5
A Klassen und methoden Java Basics - Anfänger-Themen 15
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
L Methoden Wie Löse ich ext Methoden Aufruf Fehler? Java Basics - Anfänger-Themen 3
A Bankweverwaltung mit Klassen und Methoden Java Basics - Anfänger-Themen 14
B Methoden Ausgeben Aufgabe Java Basics - Anfänger-Themen 15
M Aufsplitten von Methoden in andere Klassen Java Basics - Anfänger-Themen 2
T Methoden Verständnis Java Basics - Anfänger-Themen 14
M Feste Reihenfolge von dem Ablauf von Methoden Java Basics - Anfänger-Themen 7
G Java Abstrakte Methoden Java Basics - Anfänger-Themen 2
N Klassen Warum kann meine Klasse nicht auf Methoden der anderen Klasse zugreifen? Java Basics - Anfänger-Themen 6
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
Kirby.exe Methoden Aufrufe Java Basics - Anfänger-Themen 4
G Objekte in Methoden? Java Basics - Anfänger-Themen 13
W OOP Warenlager mit Array(Konstruktor, Methoden) Java Basics - Anfänger-Themen 39
B Variablen von Methoden übertragen Java Basics - Anfänger-Themen 2
M Unterklasse soll nicht alle Methoden erben Java Basics - Anfänger-Themen 3
Curtis_MC Parameter-Übergabe bei Klassen und Methoden Java Basics - Anfänger-Themen 12
H Aufruf von Methoden durch Methoden Java Basics - Anfänger-Themen 3
W Methoden Verständnisfrage Vererbung von Methoden Java Basics - Anfänger-Themen 14
H Wie kann ich durch Methoden definiren? Java Basics - Anfänger-Themen 8
D Methoden Scannervariablen in static Methoden Java Basics - Anfänger-Themen 5
P Verzweigungen und Methoden Java Basics - Anfänger-Themen 10
C Methoden/Klassen Übergabewerte Java Basics - Anfänger-Themen 8
B Methoden Mehrere ähnliche Methoden zusammenfassen Java Basics - Anfänger-Themen 24
C Java Klassen/Methoden/Übergabeparameter Java Basics - Anfänger-Themen 4
C Java Methoden "Parameter" Problem Java Basics - Anfänger-Themen 16
B Polymorphie Warum funktionieren polymorphe Referenzvariablen bei überschriebenen Methoden und bei nicht überschriebenen nicht? Java Basics - Anfänger-Themen 3
B Methoden Java Basics - Anfänger-Themen 1
T Körper Brechnung - Lokale Variablen in Methoden übergeben Java Basics - Anfänger-Themen 10
P Methoden richtig anwenden Java Basics - Anfänger-Themen 3
C Zusammenfassen von Methoden in einer Hilfsmethode Java Basics - Anfänger-Themen 19
A Methoden Serialisieren Java Basics - Anfänger-Themen 17

Ähnliche Java Themen

Neue Themen


Oben