Compiler-Fehler Seltsames Typverhalten eines Iterators

sarrek

Neues Mitglied
Hallo,

ich rätsel seit Stunden an einem Problem herum. Ich wollte zum üben von Iteratoren und Abstrakten Klassen mal einen Stack und eine Queue mit Generics implementieren.

Nun stehe ich vor folgendem Problem. Der Iterator der LinkedList, die im Hintergrund benutzt wird funktioniert einwandfrei. Diesen Iterator gebe ich einfach mit der abstrakten Klasse des Stacks zurück und hatte dann geplannt ihn für die Queue zu überschreiben.

Er funktioniert auch, solange man ihn als Variable zuweist. Wenn ich jedoch mit einer for-each Schleife über den Iterator gehe lande ich bei einem Compilerfehler.
Laut dem Compiler stimmt der Typ nicht überein (Integer != Object). Wenn ich jedoch als Object über den Iterator gehe und mir den Klassennamen anzeigen lasse ist dieser ein Integer.

Ich verstehe dieses Verhalten überhaupt nicht. Ich poste die Datein hier mal. In der Test.java habe ich das ganze auch nochmal kommentiert. Wenn man die for-each Zeile mit dem Integer auskommentiert und kompiliert kann man am Output den Klassennamen Integer sehen.

Ich würde mich wirklich freuen wenn mit jemand dieses Verhalten erklären könnte. Ich find im Internet nichts dazu und bei Stackoverflow konnte man mir auch nicht helfen.

SimpleLinkedList.java

Java:
import java.util.Iterator;

/**
* SimpleLinkedList: A Linked List optimized for the usage in a stack/queue.
*/

public class SimpleLinkedList<E> implements Iterable<E> {

    private Node head;
    private Node tail;
    private Node preTail;
    private int size;

    /**
     * Create a new SimpleLinkedList
     */
    public SimpleLinkedList() {
        this.size = 0;
        this.head = null;
        this.tail = null;
        this.preTail = null;
    }

    /**
     * Add a new Element at the end of the List.
     * @param E Element<T>
     */
    public void add(E element) {
        Node tmp = new Node(element);
        if(this.size == 0) { this.head = tmp; this.tail = tmp; }
        else {
            this.preTail = this.tail;
            this.tail.next = tmp;
            this.tail = tmp;
        }
        size++;
    }

    /**
     * Get first Element
     * @return E Element<T>
     */
    public E getFirst() {
        return (size != 0) ? (E) this.head.data : null;
    }

    /**
     * Get last Element
     * @return E Element<T>
     */
    public E getLast() {
        return (size != 0) ? (E) this.tail.data : null;
    }

    /**
     * Delete first Element
     */
    public void removeFirst() {
        if(!deleteTrivialCase()) {
            this.head = head.next;
            size--;
        }
    }

    /**
     * Delete last Element
     */
    public void removeLast() {
        if(!deleteTrivialCase()) {
            this.preTail.next = null;
            this.tail = this.preTail;
            size--;
        }
    }

    /**
     * Reset List
     */
    public void reset() {
        this.head = null;
        this.tail = null;
        this.preTail = null;
        this.size = 0;
    }

    /**
     * Size
     * @return int Size of List
     */
    public int size() {
        return size;
    }

    /**
     * toString representation just like an Array
     * @return String List of elements in the list.
     */
    @Override
    public String toString() {
        if(size == 0) { return "null"; }
      
        StringBuilder s = new StringBuilder();
        Node tmp = head;
      
        while(tmp != null){
            s.append(tmp.data+((tmp.next!=null)?", ":""));
            tmp = tmp.next;
        }

        return "[" + s.toString() + "]";
    }

    /**
     * Iterrator
     * @return NodeIterator
     */
    @Override
    public Iterator<E> iterator() {
        return new NodeIterator();
    }

    /**
     * Internal method to deal with trivial deletations.
     * @return boolean true if deletation is trivial.
     */
    private boolean deleteTrivialCase() {
        if(size == 0) { return true; }
        if(size == 1) { this.head = null; this.tail = null; size--; return true; }
        return false;
    }

    private class Node {
      
        private E data;
        private Node next;

        public Node(E data) {
            this.data = data;
            this.next = null;
        }
    }

    private class NodeIterator implements Iterator<E> {

        private Node current = head;

        public boolean hasNext() {
            return current != null;
        }

        public E next() {
            E cache = (E) current.data;
            current = current.next;
            return cache;
        }

        public void remove() {
            throw new UnsupportedOperationException("Operation not allowed.");
        }
    }
}

AbstractStack.java

Java:
import java.util.EmptyStackException;
import java.util.Iterator;

/**
* AbstractStack: Superclass for the Stack and Queue
**/

public abstract class AbstractStack<E> implements Iterable<E> {
    SimpleLinkedList<E> list;

    AbstractStack() {
        this.list = new SimpleLinkedList<E>();
    }
  
    /**
     * Add element to the underlaying List.
     * @param E Element
     */
    public void add(E element) {
        list.add(element);
    }

    /**
     * Reset the Stack.
     */
    public void reset() {
        list.reset();
    }

    /**
     * Stacksize
     * @return int Stacksize
     */
    public int size() {
        return list.size();
    }
   
    /**
     * Stackstate
     * @return boolean isEmpty
     */
    public boolean isEmpty() {
        return size() == 0;
    }

    /**
     * Internal function to deal with access to empty Stacks.
     * @throws EmptyStackException
     */
    protected void emptyStackSafeguard() {
        if(size() == 0) { throw new EmptyStackException(); }
    }

    /**
     * Iterator
     */
    @Override
    public Iterator<E> iterator() {
        return list.iterator();
    }

    public abstract String toString();
}

Stack.java

Java:
/**
* Stack: Implementation of a Stack using the SimpleLinkedList.
*/

public class Stack<E> extends AbstractStack {

    /**
     * Create new Stack.
     */
    public Stack() {
       super();
    }

    /**
     * Push Element onto the Stack.
     * @param E Element to push.
     */
    public void push(E element) {
       super.add(element);
    }

    /**
     * Pop Element out of the Stack.
     * @return E Last Element of the Stack.
     * @throws EmptyStackException if the Stack is empty.
     */
    public E pop() {
       super.emptyStackSafeguard();
       E cache = (E) list.getLast();
       list.removeLast();
       return cache;
    }

    /**
     * Return Element without popping it.
     * @return E Last Element of the Stack.
     */
    public E peak() {
       return (E) list.getLast();
    }
  
    /**
     * String Representation
     * @return Stack as String Representation.
     */
    @Override
    public String toString() {
        return (!isEmpty()) ? "Bottom -> " + list.toString() + " <- Top" : "null";
    }
}

Test.java
Java:
import java.lang.*;
import java.util.Iterator;

public class Test {
    public static void main(String[] args) {
        SimpleLinkedList<Integer> list = new SimpleLinkedList<Integer>();
        Stack<Integer> stack = new Stack<Integer>();

        for(int i = 0; i <= 5; i++) {
            list.add(i); stack.add(i);
        }

        //Liste Klappt ohne Probleme
        for(Integer l : list) {
            l.getClass();
        }

        System.out.println("--- Mit Iterator:");

        //Funktioniert
        Iterator it = stack.iterator();
        while(it.hasNext()) {
            System.out.println(it.next().getClass());
        }

        System.out.println("--- For Each:");

        //Funktioniert + Gibt Integer als Klasse zurück
        for(Object z : stack) { System.out.println(z.getClass()); }
      
        //Compilerfehler
        for(Integer i : stack) { System.out.println(i.getClass()); }
    }
}
 

mrBrown

Super-Moderator
Mitarbeiter
Du hast da ein Typ-Argument vergessen: public class Stack<E> extends AbstractStack ;)

Dein Stack<E> (und damit auch Stack<Integer> ist damit ein AbstractStack<Object> (verkürzt, in Wirklichkeit ein Raw-Type, was noch mal was anderes bedeutet), implementiert damit Iterable<Object> und gibt Iterator<Object> zurück.

Den gleichen Fehler bekämest du, wenn du statt Iterator it = stack.iterator(); den Typ richtig angibst: Iterator<Integer> it = stack.iterator();
 

sarrek

Neues Mitglied
Du hast da ein Typ-Argument vergessen: public class Stack<E> extends AbstractStack ;)

Dein Stack<E> (und damit auch Stack<Integer> ist damit ein AbstractStack<Object> (verkürzt, in Wirklichkeit ein Raw-Type, was noch mal was anderes bedeutet), implementiert damit Iterable<Object> und gibt Iterator<Object> zurück.

Den gleichen Fehler bekämest du, wenn du statt Iterator it = stack.iterator(); den Typ richtig angibst: Iterator<Integer> it = stack.iterator();

Danke :D

Ich habe mich erst vor ein paar Tagen angefangen mich mit Generics zu beschäftigen. Habe das wohl die gesamte Zeit übersehen. Solche Fehler sind echt ärgerlich :D Aber ich weiß jetzt was mir in der Zukunft nicht mehr passieren wird.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
MiMa Seltsames Verhalten im Konstruktor Java Basics - Anfänger-Themen 6
D Seltsames Verhalten... Java Basics - Anfänger-Themen 5
P Seltsames numerisches Problem Java Basics - Anfänger-Themen 5
K Seltsames Ergebnis in Netbeans bei einfacher Multiplikation Java Basics - Anfänger-Themen 5
J Doppelte Integer aus einem Array entfernen - seltsames Prob. Java Basics - Anfänger-Themen 5
F Seltsames Konstrukt? Java Basics - Anfänger-Themen 5
S Seltsames Java Problem Java Basics - Anfänger-Themen 3
M seltsames Phänomen in der Auswertung boolscher Variablen Java Basics - Anfänger-Themen 7
D Seltsames Problem mit this! Java Basics - Anfänger-Themen 19
M Seltsames java.util.Date Problem Java Basics - Anfänger-Themen 6
A Seltsames Verhalten beim ButtonClick (ActionListener() ) Java Basics - Anfänger-Themen 7
M Seltsames Problem Java Basics - Anfänger-Themen 4
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
laxla123 Eigenschaften eines Algorithmus (determiniert vs.. deterministisch) Java Basics - Anfänger-Themen 2
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Fehler Semikolon fehlt - ich weiss aber nicht wo da noch eines hin sollte... Java Basics - Anfänger-Themen 21
J Farbe des Striches eines TitledBorders ändern Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
walid Öffnungszeiten eines Geschäftes Java Basics - Anfänger-Themen 3
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
U Eigenschaft eines JTextfiels per ActionListener ändern... Java Basics - Anfänger-Themen 2
B Synchronisation eines kleinen Museums Java Basics - Anfänger-Themen 47
krgewb Breite und Höhe eines Bildes in base64 auslesen Java Basics - Anfänger-Themen 3
Sachinbhatt Was ist die Notwendigkeit eines Sammlungsframeworks in Java? Java Basics - Anfänger-Themen 2
N Textdatei aus Resourcen-Ordner eines Projekts/ jar-file lesen Java Basics - Anfänger-Themen 4
B Produkt eines double - streams Java Basics - Anfänger-Themen 3
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
S Variablen Letzte Zeile eines Strings entfernen Java Basics - Anfänger-Themen 1
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
J Größe eines Strings in Pixel Java Basics - Anfänger-Themen 18
M Parse-Tree eines statements darstellen Java Basics - Anfänger-Themen 0
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Hinzufügen eines Objektes in ein Objekt-Array Java Basics - Anfänger-Themen 62
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
A Rekursive Implementation eines Codes Java Basics - Anfänger-Themen 4
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
M Konstruktor ohne Übergabe eines Wertes Java Basics - Anfänger-Themen 7
M Wie kann ich in einem Konstruktor die Methode eines anderen Interfaces mit den jeweiligen Parametern aufrufen? Java Basics - Anfänger-Themen 8
M Wie erreiche ich das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 2
M Wie erreiche ich es das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 0
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
A Optimierung eines Programms: Mergen der Dateien Java Basics - Anfänger-Themen 23
melisax Alle Möglichkeiten eines Wortes angeben Java Basics - Anfänger-Themen 3
A Java, verarbeitung eines xml-files Java Basics - Anfänger-Themen 2
C Fehler beim erstellen eines Objektes Java Basics - Anfänger-Themen 3
B Konkatenieren eines Strings und inkremtierenden Zahl zu einer INT Variablen Java Basics - Anfänger-Themen 7
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
C Überprüfen eines Programms auf Syntaxfehler Java Basics - Anfänger-Themen 3
S Wie kann ich den Bereich eines Integers begrenzen? Java Basics - Anfänger-Themen 2
nonickatall Grundsätzliches Verständnisproblem des Aufbaus eines Programms Java Basics - Anfänger-Themen 19
B Downgrade eines bestehenden Projektes Java Basics - Anfänger-Themen 5
amelie123456 Geschwindigkeit der Methode bewegeDich eines Objekts ändern Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J maximaler Wert eines Integers Java Basics - Anfänger-Themen 14
TimoN11 IntelliJ , Ausgabe von einem Quellcode in Eingabe eines Quellcodes Java Basics - Anfänger-Themen 1
Z Rückgabe eines Values in umgekehrte richtung Java Basics - Anfänger-Themen 5
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
B fragen zu Aufbau eines UML-Klassendiagramm Java Basics - Anfänger-Themen 1
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
M Benutzereingabe eines Codes verbessern Java Basics - Anfänger-Themen 3
B Modulo-Operator anhand eines Beispieles erklären Java Basics - Anfänger-Themen 7
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
F Auf Variablen eines Konstruktors zugreifen Java Basics - Anfänger-Themen 4
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
C Wie kann ich Versionen eines Projektes in Eclipse erstellen? Java Basics - Anfänger-Themen 3
yoskaem Text Color durch Klicken eines Buttons in anderer Activity ändern Java Basics - Anfänger-Themen 2
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
R Löschen und ausgeben eines Teilbaums Java Basics - Anfänger-Themen 3
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
M Hilfe bei Strukturierung eines Buchungssystems Java Basics - Anfänger-Themen 3
M Erstellen eines insets Objekts, GridBagLayout Java Basics - Anfänger-Themen 13
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
W Random Zahl unter Berücksichtung eines Durchschnitts Java Basics - Anfänger-Themen 7
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
C Erstellen eines Widerstandsnetzwerks Java Basics - Anfänger-Themen 10
C Methode Seiten tauschen eines erstellten Rechtecks mit Seite A und B Java Basics - Anfänger-Themen 9
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
J Problem bei der Programmierung eines Tannenbaums Java Basics - Anfänger-Themen 9
F Berechnung der Rektaszension und Deklination eines Sterns Java Basics - Anfänger-Themen 7
1 Erste Schritte Was denkt ihr über eines meiner ersten Javaprogramme? Java Basics - Anfänger-Themen 2
A Problem bei returnen eines Wertes Java Basics - Anfänger-Themen 6
D Input/Output Problem bei der Benutzereingabe eines Befehls Java Basics - Anfänger-Themen 14
H Größte Duplikat (Größte Doppelte Wert) eines Arrays ausgeben Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben