![]() |
[JAVA] Klausurfrage zu Arrays
Hi zusammen.
Ich schreibe demnächst meine Klausur in Java. Bestandteil meines Lernens ist auch das durchgehen alter Klausuren des Dozenten. Dabei kam mi eine Frage unter, von der ich zwar die Richtige Lösung weiß, sie aber nicht nachvollziehen kann. Ich hoffe ihr könnt mir damit weiterhelfen: Zitat:
Korrekt ist allerdings Antwort C Ich hoffe mir kann hier jemand weiterhelfen. |
Ich kenn mich zwar in Java überhaupt nicht aus, aber ich denke mal das Stichwort heißt hier Call by Value,
mit der Funktion change_i wird nicht die Speicheradresse von i übergeben, das hat zur Folge, dass der Werteumtausch in der Funktion nur temporär (nur innerhalb der Funktion) ist. |
Klingt auf jeden Fall nach einer plausiblen Lösung.
Kann man das generalisieren, wann etwas "by value" und wann "by reference" übergeben wird? |
Java hat kein Call by Reference! ;-) Alles wird Call by Value übergeben.
Siehe: [Link nur für registrierte und freigeschaltete Mitglieder sichtbar. Jetzt registrieren...] Grüße MH |
Danke für die Antwort. Damit ist meine Frage hinreichend geklärt.
|
Zitat:
Allerdings wird die Speicheraddresse übergeben, sonst könnt er ja nich auf i zugreifen Oo Und das ganze Array wird nich kopiert ;) Was passiert ist folgendes: Beim Aufruf der Funktion wird change_i wird die Addresse von i1 (ich nenns jetz mal i1 und i2^^) kopiert. Deshalb wären auch alle (!)Änderungen an i1(!) in der Funktion permanent. Der Witz ist, dass die Kopie der Speicheraddresse ja geändert werden kann (was beim i = j passiert). Allerdings ändert das ja wie gesagt nur die Kopie der Addresse und hat garkeine Auswirkung auf das Array an sich. Bei einfachen Zuweisungen von Arrays werden diese nicht Kopiert sondern einfach nur die Referenzen auf die neue Umgebogen. Und "umgebogen" wird halt nur die Kopie.. deshalb ist die Ausgabe 1 =) |
Zitat:
Call by Value heißt nicht umsonst so, es wird nicht die Referenz auf die Speicheradressen, sondern nur der Inhalt an die Funktion übergeben, der dann in eine neue Speicheradresse 'gepackt' wird, nur leider wird am Ende der Funktion kein Wert und keine Speicheradresse zurückgegeben, damit verschwindet der neue Wert im RAM-Nirvana :D |
nein hier mal ein beispiel
[Link nur für registrierte und freigeschaltete Mitglieder sichtbar. Jetzt registrieren...] das objecte trotz call-by-value als referenz übergeben werden(im grunde genommen) hat performance gründe. |
Zitat:
Zitat:
|
Alle Objekte sind vom Typ Object abgeleitet, also auch Integer....
Schliesslich is Object das Grundgerüst für alle anderen Klassen, diese sind einfach nur von Object abgeleitet. Siehe dazu auch: [Link nur für registrierte und freigeschaltete Mitglieder sichtbar. Jetzt registrieren...] unter dem Begriff "Integer" Bitte nicht int mit Integer verwechseln! Das eine ist ne Klasse ;)! Grüße MH |
mit anderen worten: Bei int (wie in dem Beipsiel) bekomm ich am ende ne 1 ausgegeben.
Würde ich statt int ein: Integer i = new Integer() machen, würde ich meine 2 bekommen? |
jain, es kommt darauf an was für einen parameter die funktion erwartet.
Objekte vom Typ INTEGER casten sich,meines wissens nach selbst in einen Wert. wenn nötig. Deswegen hat Madhatter3333 auch nur teilweise recht. und wenn ein Object übergeben wird, dann wird eine Referenz übergeben, also ja genau das was du gerade meintest. btw: @mrburns, selbst wenn du diese einschränkung machst, da alle objekte vom Typ Object abgeleitet sind bedeutet dies auch jedes Objekt ist vomtyp Knicknack und vom Typ Object und somit gilt für deine Objekte auch Referenzübergabe. OOP ist sowas tolles //edit anders macht das auch keinen sinn. Ich kann zwar bestimmte eigenschaften vom Vaterobjekt dem Kindobject vorenthalten, aber wenn ich für alle meine Objekte, jedesmal ein RICHTIGES call by value ohne Referenzübergabe machen müsste, dann würden solche sachen wie JEE und größere Javaprojekte einfach bergab gehen da sie nicht performant genug sind. |
@ sirleo
Wie gesagt ich hab von Java überhaupt keinen Plan, ich habs so nur in dem Textstück gelesen, das ich gepostet hab. Ich kenn das nur von C# so, dass alle einfachen Datentypen von einer ValueType Klasse abgeleitet sind und deshalb nicht direkt wie Zeiger behandelt werden, oder in C++ werden nur Variablen als Zeiger verwendet, die ausdrücklich als solche definiert sind, das beides scheint wohl bei Java nicht der Fall zu sein. :D |
ich bin auch nicht so der Javacrack(hatte damit nur ein paar Jahre zu tun).
Java hat wenn du so willst 2 Ansätze. Alles ist ein objekt aber es gibt auch primitive Datentypen, was zB dem valueType-Klasse in C# entspricht. Aber du hast auch, Objekte der Primitiven Datentypen(haste in C# auch, ich sach nur new Int()); btw, die teile musste in C# auch als Pointer handhaben können, sonst wäre Marshalling bei Unmannaged Code mit DllImport so eine schwierige Sache, obwohl man da dann einen Wrapper vom Typ System.IntPtr benutzt um den Pointer zu übergeben, aber möglich ist es wenn auch kein Pointer vom Typ *int [Link nur für registrierte und freigeschaltete Mitglieder sichtbar. Jetzt registrieren...] . btw: meine argumentationskette ist Grundlage von so ziemlich jeder OOP-Sprache die ich kenne, hat also nicht unbedingt was mit der Sprache zu tun,sondern ist vielmehr eine Frage der Eigenschaften von OOP und cleverem Design. Und um nochmal auf das Thema zurrückzukommen hier ein kleines Beispiel : //edit BTW, ganz vergessen, Metphist0,wegen deiner ursprünglichen Fragestellung: Alles was hier über call-by-reference und call-by-value und objecte etc gesagt wurde ist wahr, aber halt nur bis zu einem gewissen Grad. Integer ist immutable genauso wie andere Objekte die Datentypen enthalten. Und sie haben auch noch die Eigenschaft das sie, als einzige objekte mittels call-by-value übergeben werden. Alle anderen Objekte,vor allem deine eigenen Objekte, sind Call-by-reference. D.h. wird bei deinem Codebeispiel aus der Klausur auch 1 ausgegeben. (sowas hat man mir in bezug auf Java nie beigebracht nur dieses call-by-Reference gilt FÜR ALLE OBJEKTE *grübel* naja, selbst lesen macht klug :D ) und somit ist mein letzter Post vor diesem hier, nicht wirklich richtig.... hey was gelernt :D |
Zitat:
Ich versuche mich jetzt seit ca. 2 Wochen in C# und in der Schule behandeln wir nun seit ca 1 1/2 Jahren C++, hatten aber merkwürdiger Weise nichts über OOP, das hab ich mir vor ca. einer Woche versucht anzueignen :unibrow: Aber ich glaube mit Vererbung gehen wir schon viel zu weit, ursprünglich wollte er ja nur wissen warum nicht die 2 ausgegeben wird :D @Thema Zitat:
Code:
object i=new integer(); // Ok, dann hatte ich in dem Artikel was Grundlegendes falsch verstanden, ich les den lieber nochmal... |
Lies dir dazu mal Polymorphie durch.
D.h. die Variable vom Typ Object kann jedes Objekt in Java aufnehmen, aber Dank polymorphie hat jedes Objekt das du in die variable vom Typ Object packtst immer noch die gleichen eigenschaften. |
Das ist zwar alles interessant(und vieles richtig), aber der Grund, dass die Methode nicht funktioniert ist, dass nicht auf dem uebergebenen Objekt gearbeitet wird (ein Array ist auch mit einem primitiven Datentyp ein Objekt) sondern ein neues erzeugt wird und nur in der Methode die Vatiablen geaendert werden:
public static void change_i(int[]i){ i[0]=2; return; } sorgt fuer eine 2 Das mit dem Integer (als Objekt) ist zwar richtig, allerdings ist die set-Methode gesperrt - es laesst sich also nicht so benutzen. |
Zitat:
Der wirft nur einen Fehler aus. So wie ich das sehe. :-D |
Ich weiss nicht was Du meinst - Ich habs gerade noch einmal hieraus zusammenkopiert und es funktioniert genau wie gesagt - oder ich versteh den Witz nicht so ganz :confused:
|
Zitat:
Zitat:
Wenn du eine "2" ausgeben möchtest musst du zusätzlich das void in das notwendige Format bringen: Zitat:
|
lol. setzen 6.
aber nichtsdestotrotz willkommen im forum ;) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:39 Uhr. |
Powered by vBulletin® (Deutsch)
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.