Ihre Funktion eine Reihe von Fehlern hat.
- Sie tun eine Referenz-Gleichheitsprüfung und nicht die Wert-Gleichheitsüberprüfung.Für eine Wert-Gleichheitsprüfung verwenden Sie immer die Methode "equals". Sie werden keine Compiler-Fehler für diese Art von Fehlern erhalten. Sie werden erhalten unerwünschte Ausgabe.
- Nicht alle Kontrollflüsse in Ihrer Funktion haben eine return-Anweisung, obwohl Ihre Methodensignatur eine nicht void return-Anweisung vorschlägt. Dies erzeugt einen Compiler-Fehler, den Sie in Ihrem Code sehen.
- Sie haben mehrere Return-Anweisungen. Dies ist weder ein Compilerfehler noch ein Laufzeitfehler. Aus der Sicht der guten Programmierpraxis ist es jedoch nicht die beste Idee, mehrere Return-Statements zu haben. Sie können eine Flag-basierte Return-Anweisung am Ende ausführen.
- Sie entfernen Elemente aus einem Auflistungsobjekt, während Sie es durchlaufen. Abhängig vom Typ des Sammlungsobjekts, das Sie verwenden, kann es zur Laufzeit eine ConcurrentModificationException-Ausnahme auslösen. Sie müssen stattdessen einen fehlersicheren Iterator verwenden, falls verfügbar.
Ich habe versucht, Ihr Programm zu korrigieren. Sehen Sie, wenn das besser Sinn macht:
Das obige Programm funktioniert, wenn der Iterator ausfallsicher ist. Z.B. Wenn Ihr myList-Objekt vom Typ CopyOnWriteArrayList ist, ist sein Iterator fehlersicher. Aber wenn Ihr myList-Objekt vom Typ einer solchen einfachen ArrayList ist, die einen schnellen Iterator zurückgibt, gibt Ihnen die obige Methode einen CME.
Wenn Ihr myList Sammlung Objekt vom Typ Liste ist, können Sie etwas so einfach versuchen, so:
public boolean deleteItem(String p) {
//removeAll will return true if at least 1 element is removed
return this.myList.removeAll(Collections.singletonList(p));
}
Alternativ, wenn Sie Java 8 verwenden, können Sie wie etwas tun folgenden:
public boolean deleteItem(String p) {
//removeIf will return true if at least 1 element is removed
return this.myList.removeIf(item -> item != null && item.equals(p));
}
Hoffe das hilft dir ein bisschen.
Entfernen Sie den Else-Block und verschieben Sie 'return false;' außerhalb der for-Schleife. –
Was @John sagte, plus '.equals()', um Strings zu vergleichen (nicht '=='). – Bohemian
Verwenden Sie einen * Debugger *. Wir sind nicht dein Debugger. Wenn Sie den Code durchgehen, können Sie sofort Ihren Fehler sehen. – Andreas