Minitutorial - Cloneable: Unterschied zwischen den Versionen
K |
K (→Es kann auch notwendig sein, eine "tiefe" Kopie zu erstellen) |
||
Zeile 44: | Zeile 44: | ||
Object value; | Object value; | ||
Entry next; | Entry next; | ||
+ | Entry(Object key, Object value, Entry next){ | ||
+ | this.key =key; | ||
+ | this.value = value; | ||
+ | this.next =next; | ||
+ | } | ||
//Recursively copy the linked list headed by this Entry | //Recursively copy the linked list headed by this Entry | ||
Entry deepCopy(){ | Entry deepCopy(){ |
Version vom 8. August 2008, 20:53 Uhr
Inhaltsverzeichnis
- 1 Alle Klassen, die "Cloneable" implementieren, sollten "public Object clone" überschreiben
- 2 Danach sollte sie noch irgendwelche Felder bearbeiten, die zusätzliche Beachtung erfordern
- 3 Es kann auch notwendig sein, eine "tiefe" Kopie zu erstellen
- 4 "final" Schlüsselwörter müssen eventuell entfernt werden
Alle Klassen, die "Cloneable" implementieren, sollten "public Object clone" überschreiben
Diese "public" Methode sollte zunächst "super.clone()" aufrufen. Beispiel:
<code=java>public Object clone() throws CloneNotSupportedException {
Object result = super.clone(); return result;
}</code=java>
Danach sollte sie noch irgendwelche Felder bearbeiten, die zusätzliche Beachtung erfordern
Gewöhnlich bedeutet dies, "mutable" Objekte zu kopieren und die Referenzen zu diesen Objekten mit Referenzen auf den Kopien zu ersetzen. Am einfachsten erreichen wir dies, indem wir rekursiv "clone" auf den betreffenden Feldern aufrufen. Beispiel:
<code=java>public Object clone() throws CloneNotSupportedException {
MeineKlasse result = (MeineKlasse)super.clone(); result.elements = (Object[]) elements.clone(); return result;
}</code=java>
Es kann auch notwendig sein, eine "tiefe" Kopie zu erstellen
Beispiel:
<code=java>public class MeineKlasse implements Cloneable{
privates Entry[] buckets = ...;
public Object clone() throws CloneNotSupportedException{ MeineKlasse result = (MeineKlasse)super.clone(); result.buckets = new Entry[buckets.length]; for(int i = 0; i < buckets.length; i++){ if(buckets[i] != null){ result.buckets[i] = buckets[i].deepCopy(); } } return result; }
private static class Entry{ Object key; Object value; Entry next; Entry(Object key, Object value, Entry next){ this.key =key; this.value = value; this.next =next; } //Recursively copy the linked list headed by this Entry Entry deepCopy(){ return new Entry(key, value, next == null ? null : next.deepCopy()); } //Iteratively copy the linked list headed by this Entry (recommended for big lists)
// Entry deepCopy(){ // Entry result = new Entry(key, value, next); // for(Entry p = result; p.next != null; p = p.next) // p.next = new Entry(p.next.key, p.next.value, p.next.next); // return result; // }
}
}</code=java>
"final" Schlüsselwörter müssen eventuell entfernt werden
Um eine Klasse "cloneable" zu machen, kann es manchmal notwendig sein, von einigen Feldern die "final" Schlüsselwörter zu entfernen.