OOP Objekte als Return-Werte: Einen Klon zurückgeben oder Instanz auf das Feld?

Skrodde

Aktives Mitglied
Hallo zusammen,
ich habe in meinem Projekt mehrere Klassen, welche als Felder weitere Objekte gespeichert haben, z.B.
Java:
public class LinearFunction implements Function{	
	private List<OptTerm> terms;
	private Number constantTerm;

	public void setTerms(List<OptTerm> terms) {
	}

	public List<OptTerm> getTerms() {
	}
}
Nun meine Fragen:
  • Sollte man direkt die Referenz auf das Objekt (hier die Liste) zurückgeben und darauf vertrauen, dass der Anwender nicht in der Liste schreibt, wenn man nicht möchte, oder sollte man die Liste duplizieren?
  • Im letzteren Fall: Ich habe gelesen, dass .clone() nur eine Kopie, aber keine Deep-Kopie erzeugt. Gibt es eine bessere Möglichkeit, als alle Klassen, die ich habe mit einer eigenen Clone() Methode auszustatten, welche dann eine Deep-Copy erzeugt?
Vielen Dank und Gruß, Martin
 

Skrodde

Aktives Mitglied
Hallo,
vielen Dank für die Antworten soweit. Der Typ mit der Collections-Methode ist ja schon mal super. Damit habe ich wohl die Hälfte des Aufwands erschlagen. Für den Rest werde ich wohl die verlinkte Klasse nutzen, dann bin ich bei allem auf der sicheren Seite.
Allerdings habe ich jetzt die Klassen-Methode
Code:
public static Object clone(Object copyObject)
ausprobiert und bekomme eine
Code:
java.io.NotSerializableException
Komme ich nun nicht vom Regen in die Traufe? Ich muss zwar
Code:
clone()
nicht mehr bei jedem Objekt implementieren, dafür aber jedes Objekt serialisierbar machen , oder? :(
 
B

bygones

Gast
nur fuers clonen sollte man kein Serializable brauchen, serialisierst du deine Objekte auch ?
 
Zuletzt bearbeitet von einem Moderator:

Skrodde

Aktives Mitglied
nur fuers clonen sollte man kein Serializable brauchen, serialisierst du deine Objekte auch ?
Mit der oben genannten Klasse können wohl nur serialisierbare Objekte geklont werden.
Nach dem Kommentar von Maki mache ich mir lieber selbst noch Gedanken, ob ich nicht irgendwie verhindern kann, dass ich Klonen oder Ähnliches überhaupt brauche. Das alles scheint doch komplizierter zu sein, als ich dachte. :autsch:
 

freez

Top Contributor
Sollte man direkt die Referenz auf das Objekt (hier die Liste) zurückgeben und darauf vertrauen, dass der Anwender nicht in der Liste schreibt, wenn man nicht möchte, oder sollte man die Liste duplizieren?

Das "Sollte man" solltest du entscheiden. Der "Anwender" ist ja in der Regel ein Entwickler. Prinzipiell spricht erst mal nichts dagegen, dass er deine Klasse nutzt und auch die Daten manipuliert, soweit es ihm möglich ist. Hat die Manipulation Auswirkungen auf andere Klassen, könnte man schon drüber nachdenken.
Aber ich persönlich kenne fast gar keine Fälle, wo jemand mal eine Deep Copy gebraucht habe, weil er Angst haben musste, dass jemand etwas verändert und es Auswirkungen haben könnte. Soll nicht heißen, dass man es nie braucht, nur dass es einfach auf dein Anwendungfall drauf ankommt. Und wie gesagt, es ist ja kein "Anwender" im eigentlichen Sinne ... es ist immer noch ein Entwickler, der deine Klasse nutzt und auch wissen sollte, was passiert, wenn er was ändert (sofern du es ihm dokumentierst :D).
 

Marco13

Top Contributor
Das mit der Rückgabe ist über Collections#unmodifiableList ja weitgehend geklärt. Die Frage nach der "Tiefe" stellt sich noch
linearFunction.getTerms().get(0).modifyThisInSomeWay(); // Erlaubt?

Aber zum Setter wurde noch nichts gesagt. Was würdest du da reinschreiben? Ein einfaches
Java:
public void setTerms(List<OptTerm> terms) 
{
    this.terms = terms;
}
würde die Collections#unmodifiableList nämlich ggf. ad absurdum führen. Man sollte auch in Betracht ziehen, gar keinen setter für die Liste anzubieten, sondern nur add/remove, womit man die (im Konstruktor erstellte, finale, private) Liste füllen kann.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
schegga_B javax.crypto - Cipher Objekte - Sevice Provider matching? Allgemeine Java-Themen 1
berserkerdq2 Weiß jemand wie ich im Scenebuilder das Fenster so darstellen kann, dass beim Vollbildmodus die Objekte so angezeigt werden? Allgemeine Java-Themen 1
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
N einem Array Objekte hinzufügen die ihr Array position gespeichert haben Allgemeine Java-Themen 34
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
L Objekte in Set nicht gefunden Allgemeine Java-Themen 13
Avalon Data Transfer Objekte aus Datenbank erstellen Allgemeine Java-Themen 8
G Objekte mit Strings Aufrufen Allgemeine Java-Themen 8
H Objekte speichern und laden Allgemeine Java-Themen 10
H Objekte speichern und laden Allgemeine Java-Themen 1
MiMa Referenz auf Objekte und deren Inhalte Allgemeine Java-Themen 12
W Objekte reproduzieren Allgemeine Java-Themen 2
W Objekte per Reflexion instanziieren Allgemeine Java-Themen 7
W Unittest - Objekte simulieren Allgemeine Java-Themen 7
T OOP Objekte mit Erweiterung Initialisieren Allgemeine Java-Themen 6
O Erste Schritte Objekte als Datenelemente Allgemeine Java-Themen 14
J Equals Mock Objekte Allgemeine Java-Themen 5
J Mockito - Objekte miteinander vergleichen (equals) Allgemeine Java-Themen 6
N Bei Mouse Events nicht mehrere Objekte erstellen Allgemeine Java-Themen 13
J Zugriff auf erstellte Objekte einer Klasse von einer Klasse ausserhalb Allgemeine Java-Themen 3
J Java Objekte = null, Garbagecollector Allgemeine Java-Themen 12
F Listen - Mehrere Objekte Allgemeine Java-Themen 1
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
F Objekte erzeugen Allgemeine Java-Themen 1
E Threads ThreadPoolExecutor remove mit callable Objekte Allgemeine Java-Themen 3
P mehrer Verschiedene Objekte in einer Klasse erstellen. Allgemeine Java-Themen 4
E OOP Objekte und Methoden Allgemeine Java-Themen 1
@SupressWarnings() Umgebungsvariable Objekte "gekoppelt" Allgemeine Java-Themen 6
S Algorithmus um Objekte auf einer Flaeche mit gleichem Abstand anzuordnen..? Allgemeine Java-Themen 20
C Objekte in Array List speichern? Allgemeine Java-Themen 1
OnDemand Objekte speichern Allgemeine Java-Themen 8
B Objekte anhand von Properties file Allgemeine Java-Themen 41
U Tiefe Objekte schreiben Allgemeine Java-Themen 1
R Abstrakte Basisklasse und instanzierte Objekte der abgeleiteten Klasse als Basisklasse übergeben Allgemeine Java-Themen 2
E 3D Objekte in 2D Bild finden Allgemeine Java-Themen 5
J Daten aus GUI auslesen und in Objekte umwandeln Allgemeine Java-Themen 6
F FileOutput/Input Objekte Allgemeine Java-Themen 6
OnDemand Objekte serialisieren Allgemeine Java-Themen 3
J unterschiedliche Objekte, selbe getter und setter Allgemeine Java-Themen 15
L Lib gesucht: Java-Objekte mit JSON Allgemeine Java-Themen 2
U Set erklären dass objekte gleich sind Allgemeine Java-Themen 12
E Best Practice Verdammt große Objekte Allgemeine Java-Themen 10
B Mehrere Objekte verschlüsselt serialisieren Allgemeine Java-Themen 6
G Liste anzahl der gleichen Objekte Allgemeine Java-Themen 6
N Objekte an eine andere Applikation übergeben Allgemeine Java-Themen 3
N 2 Objekte zu einer Gruppe zusammenfügen Allgemeine Java-Themen 7
M Instanzierte Objekte in XML Dokument speichern Allgemeine Java-Themen 3
B Verschiedene Objekte in Abhängigkeit eines Typs instanziieren. Allgemeine Java-Themen 17
K Input/Output Im Programm instanzierte Objekte Speichern und laden Allgemeine Java-Themen 3
H Objekte Serialisiert speichern Allgemeine Java-Themen 10
L MouseListener für viele Objekte erstellen Allgemeine Java-Themen 16
5 Objekte Sortieren lassen Allgemeine Java-Themen 7
N Objekte aus Array Inhalt erzeugen Allgemeine Java-Themen 8
L Input/Output Textdatei in Objekte überführen? Allgemeine Java-Themen 4
R Input/Output Objekte speichern ohne überschreiben Allgemeine Java-Themen 7
A Collections HashMap.containsKey findet keine immutablen Objekte Allgemeine Java-Themen 3
H Threads Thread stirbt aber Objekte in ihm leben weiter?! Allgemeine Java-Themen 9
M Java Objekte in XML mit JAXB Allgemeine Java-Themen 9
C Strings und JSON Objekte so klein wie möglich im Speicher ablegen Allgemeine Java-Themen 5
H COM-Objekte/ AktiveX Objekte Allgemeine Java-Themen 4
C Script für Website mit Objekte Ausblenden Allgemeine Java-Themen 3
M Txt einlesen & Objekte erzeugen Allgemeine Java-Themen 2
X Objekte aus TableModel serialisieren und deserialisieren Allgemeine Java-Themen 4
T ObjectInputStream - Arrayliste, die unbekannte Objekte enthält Allgemeine Java-Themen 9
B class dateien "einlesen" und objekte erzeugen Allgemeine Java-Themen 6
D Grafische Objekte zeichnen Allgemeine Java-Themen 4
A Wie zur Laufzeit auf Objekte zugreifen Allgemeine Java-Themen 7
F Referenzen auf Objekte Allgemeine Java-Themen 5
H Eclipse und Objekte Allgemeine Java-Themen 6
S Objekte die Objekte enthalten: Keine Vererbung Allgemeine Java-Themen 4
E Objekte in einer Liste suchen. Allgemeine Java-Themen 4
I Über eine Liste iterieren und Objekte löschen. Wie löst man das sauber? Allgemeine Java-Themen 5
I Pattern zum Erweitern existierender Objekte Allgemeine Java-Themen 4
N Dynamische Objekte / DB Allgemeine Java-Themen 5
J Objekte binär speichern Allgemeine Java-Themen 10
TiME-SPLiNTER Unbekannte Anzahl serialisierter Objekte lesen Allgemeine Java-Themen 2
V Objekte in Kategorien einteilen. Allgemeine Java-Themen 6
M 3D Objekte mit einer Linie Verbinden Allgemeine Java-Themen 3
F Wie zur Laufzeit ganz neue Objekte erzeugen? Allgemeine Java-Themen 5
A Dummy-Objekte für Webgui erzeugen Allgemeine Java-Themen 12
W Objekte speichern mit JFileChooser Allgemeine Java-Themen 8
D befehl auf mehrere objekte anwenden Allgemeine Java-Themen 7
L Objekte in Liste packen Allgemeine Java-Themen 2
S XML in Objekte wandeln. Euer Rat? Allgemeine Java-Themen 12
G Objekte serialisieren Allgemeine Java-Themen 2
L Parameter-Objekte verändern oder nicht? Allgemeine Java-Themen 6
D Objekte nur unter bestimmten Voraussetzungen erzeugen Allgemeine Java-Themen 4
S Objekte mit Arrays Allgemeine Java-Themen 9
F Objekte oder besser ID in Listen speichern? Allgemeine Java-Themen 2
S erzeugte objekte zählen Allgemeine Java-Themen 3
U auf Objekte mit variablem Namen zugreifen Allgemeine Java-Themen 4
Airwolf89 dynamischer Zugriff auf Variablen/ Objekte Allgemeine Java-Themen 4
Landei Objekte ohne Konstruktoraufruf erzeugen Allgemeine Java-Themen 7
E tiefe Kopie nicht serialisierbarer Objekte Allgemeine Java-Themen 3
J Speicherbedarf und persistente Objekte Allgemeine Java-Themen 4
J ArrayList Objekte anhand Propertywerte filtern Allgemeine Java-Themen 3
R Moeglichst viele Datumsstrings in Date Objekte konvertieren? Allgemeine Java-Themen 3
J Eindeutige ID für Objekte als Keys in TreeMap Allgemeine Java-Themen 12
G Unveränderbare Objekte Allgemeine Java-Themen 9

Ähnliche Java Themen

Neue Themen


Oben