Ist der Code richtig

Lolo123

Neues Mitglied
Hallo zusammen! Ich bin Anfänger und bräuchte Hilfe. In der Klausur war gefordert, dass jedes Objekt vom LogEntry eine eindeutige aufsteigende fortlaufende Nummer bekommt. Das hatte ich dann programmiert:
public class LogEntry {
private String date;
private String applicationName;
private String iPAddress;
private String logLevel;
private String message;
private String countryID;
private int logEntryID;
private int fortlaufendeNR = 0;

public LogEntry(String date, String applicationName, String iPAddress,
String logLevel, String message, String countryID) {
fortlaufendeNR++;
this.date = date;
this.applicationName = applicationName;
this.iPAddress = iPAddress;
this.message = message;
this.countryID = countryID;
this.logEntryID = this.fortlaufendeNR;

switch (logLevel){
case "debug": this.logLevel = "debug"; break;
case "info": this.logLevel = "info"; break;
case "warning": this.logLevel = "warning"; break;
case "error": this.logLevel = "error"; break;
case "fatal": this.logLevel = "fatal"; break;
default:
System.out.println("undefiniert"); break;


}

}

ich habe null Punkte bekommen. Kann mir einer erklären, wieso der Code falsch ist? Danke im Voraus :)
 
K

kneitzel

Gast
Sowas kannst Du selbst austesten. Hast Du mal ein kleines Projekt gemacht und mit der Klasse herum gespielt? Also einfach noch eine public static void main hinzu fügen und dann schauen, ob die Anforderung erfüllt ist:
Einfach mal mehrere Instanzen erzeugt: Hat jede Instanz eine eindeutige, aufsteigende und fortlaufende Nummer?

Du wirst dann feststellen, dass diese Anforderung nicht erfüllt ist, denn fortlaufendeNR ist nicht static. Somit ist dies ein Attribut, das jede Instanz bekommt. Jede Instanz hat also seine eigene fortlaufendeNr, diese ist erst 0 und wird dann im Konstruktor um eins erhöht. Somit haben alle Instanzen eine logEntryID von 0.
 

Lolo123

Neues Mitglied
Sowas kannst Du selbst austesten. Hast Du mal ein kleines Projekt gemacht und mit der Klasse herum gespielt? Also einfach noch eine public static void main hinzu fügen und dann schauen, ob die Anforderung erfüllt ist:
Einfach mal mehrere Instanzen erzeugt: Hat jede Instanz eine eindeutige, aufsteigende und fortlaufende Nummer?

Du wirst dann feststellen, dass diese Anforderung nicht erfüllt ist, denn fortlaufendeNR ist nicht static. Somit ist dies ein Attribut, das jede Instanz bekommt. Jede Instanz hat also seine eigene fortlaufendeNr, diese ist erst 0 und wird dann im Konstruktor um eins erhöht. Somit haben alle Instanzen eine logEntryID von 0.
Danke!! Bei der Lösung steht aber, ich hätte das set
Sowas kannst Du selbst austesten. Hast Du mal ein kleines Projekt gemacht und mit der Klasse herum gespielt? Also einfach noch eine public static void main hinzu fügen und dann schauen, ob die Anforderung erfüllt ist:
Einfach mal mehrere Instanzen erzeugt: Hat jede Instanz eine eindeutige, aufsteigende und fortlaufende Nummer?

Du wirst dann feststellen, dass diese Anforderung nicht erfüllt ist, denn fortlaufendeNR ist nicht static. Somit ist dies ein Attribut, das jede Instanz bekommt. Jede Instanz hat also seine eigene fortlaufendeNr, diese ist erst 0 und wird dann im Konstruktor um eins erhöht. Somit haben alle Instanzen eine logEntryID von 0.
danke!! Bei der Lösung steht aber noch dabei, ich hätte setLogEntryId verwenden müssen.. wäre es komplett falsch nur LogEntryId hinzuschreiben? Danke für den Tipp mit dem Testen, nur war ich so nervös
und hatte einen enormen Zeitdruck
 
K

kneitzel

Gast
danke!! Bei der Lösung steht aber noch dabei, ich hätte setLogEntryId verwenden müssen.. wäre es komplett falsch nur LogEntryId hinzuschreiben? Danke für den Tipp mit dem Testen, nur war ich so nervös
und hatte einen enormen Zeitdruck
Also diesbezüglich gibt der Text, den Du uns gegeben hast, nichts her. Der einzige Fehler, den ich sehe, ist eben das fehlende static bei fortlaufendeNr. (Und als Folge vom static wäre der Zugriff per "this." aus meiner Sicht auch etwas, das ich bei einem Code Review anmeckern würde. Das wäre zu streichen oder eben durch "LogEntry." zu ersetzen.

Das im Konstruktor kein Setter benutzt wird, ist aus meiner Sicht durchaus korrekt. Es ist auf keinen Fall "komplett falsch" (Es sei denn, die Aufgabe fordert dies explizit). Ich würde bei einem Code Review eher die Nutzung eines Setters bemängeln (bzw. das würde ggf. ein Code-Analyse Tool für mich übernehmen) Das erläutere ich weiter unten noch kurz.

Ich kann jetzt nur über das schreiben, was ich von so einer Klasse erwarten würde. Wenn eine Aufgabe hier anderes vorgibt, dann ist das Nachfolgende ohne Bedeutung!

Du hast in Deinem Code weder Getter noch Setter gezeigt. Wenn das von der Aufgabe gefordert war, dann ist das ein Fehler. Setter würde ich bei so einer Klasse generell nicht sehen. Ein LogEntry wird erstellt und wäre dann für mich ein "Value Type", also etwas, das ich als festen Wert sehen würde, der nicht mehr veränderbar wäre.
Ein public Setter auf logEntryId würde ich sogar als Fehler bewerten, da ich dem Text entnehme, dass diese id eben "eine eindeutige, aufsteigende und fortlaufende Nummer" sein soll. Und das ist eine Vorgabe an die Klasse und die Klasse muss dies sicher stellen. Ein Setter würde dies brechen bzw. müsste ein Setzen unterbinden, so die Id bereits gesetzt worden wäre.

Wenn ich so eine Klasse schreiben würde, dann wäre das vermutlich etwas wie:
Java:
public class LogEntry {
    @Getter
    private final int id;
    private static int lastUsedId;
    // ...
    public LogEntry(....) {
        lastUsedId++;
        id = lastUsedId;
        // ...
    }
}

Ich habe es stark gekürzt. Das @Getter soll einfach anzeigen, dass ich hier ein Getter schreiben würde. Die Bezeichner habe ich etwas angepasst - u.a. auch, weil ich da deutlich machen wollte, dass dies nicht eine Lösung für Deine Aufgabe ist. id ist aber nur id, denn es ist ja in der Klasse LogEntry, also ist diese id eine logEntryId. Und fortlaufendeNr wäre kein englischer Bezeichner. Entweder ich mache es auf Englisch oder auf Deutsch... Aber das nur am Rande.

Weggelassen habe ich alle anderen Werte, die zu der Klasse gehören, die in dem Konstruktor als Parameter mit angegeben werden müssen. Die alle eine Instanzvariable bekommen müssen und einen Getter. Setter, wie bereits angedeutet, sehe ich nicht!

Nun noch wie versprochen eine kurze Erläuterung, warum es problematisch sein kann, in einer (non final) Klasse im Konstruktor eine Methode zu verwenden:

Nehmen wir einfach einmal eine Klasse an, die nicht final ist und die im Konstruktor eine Methode aufruft (Es muss kein Setter sein - jede Methode geht!)
Java:
public class Basis {
    public void someMethod() {}
    
    public Basis() {
        someMethod();
    }
}

Nun leiten wir einfach mal eine Klasse davon ab:
Java:
public class Derived extends Basis {
    public String someString;
    
    public Derived() {
        someString = "Hallo";
    }
    
    public someMethod() {
        if (someString.equals("Hallo")) {
            System.out.println("Ich sage mal Hallo!");
        }
    }
}

Das soll jetzt einfach mal ein Auszug sein. Macht nicht wirklich was sinnvolles. Aber der Code sieht doch ok aus, oder? Derived hat eine Instanzvariable. Diese wird im Konstruktor gesetzt.
Und dann hat die Klasse eine Methode someMethod. Jetzt haben wir auch Basis direkt drüber und die Klassen sind klein, daher wissen wir: Ups, die Methode überschreibt eine vorhandene ...

Was passiert denn nun, wenn ich eine Instanz von Derived erzeuge:
-> Es wird eine Instanz erzeugt und die Instanzvariablen bekommen ihr ersten Werte (someString ist damit null)
-> Es wird der Konstruktor von Derived aufgerufen.
-> Da abgeleitete Klasse: Es wird der Konstruktor von Basis aufgerufen.
-> Der Konstruktor ruft someMethod auf, da Derived die Methode überschrieben hat, wird die neue Version aufgerufen
-> Da someString null ist, wird eine NullPointerException geworfen beim equals Aufruf.

Blödes Verhalten eines Programmes, das wir so nicht wollen! Vor allem können die Klassen von unterschiedlichen Entwicklern gebaut werden oder so ... evtl. gab es someMethod ursprünglich gar nicht und der Entwickler von Basis hat keine Ahnung, dass da in Derived so eine Methode vorhanden ist! Das kommt später.... Und plötzlich knallt es bei Derived trotz einer "harmlosen" Änderung ...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Ich weiß nicht, wie ich meinen Code richtig designen soll und komme nicht weiter Java Basics - Anfänger-Themen 4
S Code richtig / besser machbar? (Nicht sicher, ob Code selbst falsch ist) Java Basics - Anfänger-Themen 4
W HTML Code, Umlaute werden nicht richtig dargestellt Java Basics - Anfänger-Themen 7
K Kreis Zeichnen ? Code Richtig aber keine Zeichung Java Basics - Anfänger-Themen 8
M Code-Abschnitt richtig kommentieren Java Basics - Anfänger-Themen 2
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
T Kann mir jemand wörtlich erklären, was in dem Code genau passiert? Java Basics - Anfänger-Themen 1
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
terashy VS Code Project run error Java Basics - Anfänger-Themen 10
JaZuDemNo Code Erklärung Java Basics - Anfänger-Themen 3
M Connect-4-Code analysieren Java Basics - Anfänger-Themen 2
N BMI Rechner Was haltet ihr von dem Code habt ihr Verbesserungsvorschläge weil design teschnisch ist das nicht das geilste würde das gerne überarbeiten Java Basics - Anfänger-Themen 12
W In alten Code zurück- und dort wieder zurechtfinden? Java Basics - Anfänger-Themen 17
T code so schreiben das er von sich selber anpasst (code soll die anzahl aller bustaben bestimmen) Java Basics - Anfänger-Themen 16
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
T Fehlercode bei code der das Alter ausrechnet Java Basics - Anfänger-Themen 2
T Text einlesen code was kommt dahin? Java Basics - Anfänger-Themen 1
jhfjeh Strukturgramm in code Java Basics - Anfänger-Themen 11
D Tipps zum Code Java Basics - Anfänger-Themen 24
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
ohneInformatik; For Schleife. Was macht dieser Code?? Java Basics - Anfänger-Themen 5
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
Say Stelle in Code herausfinden, wie geht man vor? Java Basics - Anfänger-Themen 12
Say do-While Code Ausführung Java Basics - Anfänger-Themen 3
W Rückfrage zur Programmgestaltung (clean code) Java Basics - Anfänger-Themen 12
M intelliJ auf neuem PC, plötzlich kein Code Java Basics - Anfänger-Themen 3
Pinhg Sound in Greenfoot Code einbinden Java Basics - Anfänger-Themen 2
C Java boolean Code läuft nicht Java Basics - Anfänger-Themen 5
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
J Größter gemeinsamer Teiler: mein Code Java Basics - Anfänger-Themen 6
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
A Wie könnte man diesen Code kürzer machen ? Java Basics - Anfänger-Themen 7
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
Alen123 Warum funktioniert mein Code nicht? Java Basics - Anfänger-Themen 64
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
S Hilfe bei Umänderung von Java Code Java Basics - Anfänger-Themen 16
I Code wird nicht ausgeführt Java Basics - Anfänger-Themen 2
K Wie kann man diesen Code schnell und effizient interpretieren (Man hat nur 4 Minuten) Java Basics - Anfänger-Themen 3
R ISBN-10-Code überprüfen Java Basics - Anfänger-Themen 7
I Bitte um Hilfe zu unterstehenden Code Java Basics - Anfänger-Themen 6
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
I HTML Code säubern Java Basics - Anfänger-Themen 4
B Brauche Hilfe zu einem Code Java Basics - Anfänger-Themen 5
Temsky34 Problem mit dem Code Java Basics - Anfänger-Themen 17
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
N Java-Code abwärtskompatibel machen Java Basics - Anfänger-Themen 4
J Erste Schritte Was mache ich in meinem Code falsch. Java Basics - Anfänger-Themen 3
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
S Compiler-Fehler Nicht adressierbarer Code ( Non-addressable code ) Java Basics - Anfänger-Themen 5
Aemulit Java Schaltjahr berechnen Code Java Basics - Anfänger-Themen 7
A Code Problem Java Basics - Anfänger-Themen 6
C Fehler im Code Java Basics - Anfänger-Themen 10
A Zu einem bestimmten Ort im Code springen Java Basics - Anfänger-Themen 11
josfe1234 code vereinfachen Java Basics - Anfänger-Themen 15
nonickatall Ausführbarkeit von Code testen bzw. Remote Debugging Java Basics - Anfänger-Themen 4
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
G Programm Code Java Basics - Anfänger-Themen 5
C Code zusammenfassen Java Basics - Anfänger-Themen 5
I Erklärung zum Java Code Java Basics - Anfänger-Themen 2
T Programmablaufsplaninterpretation in Code umformen Java Basics - Anfänger-Themen 1
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
AlexVo String zu Java Anweisung getString("*** java code ***") Java Basics - Anfänger-Themen 19
M ISBN-Code Java Basics - Anfänger-Themen 26
B Zeitgleiches Arbeiten am Code mit mehreren Personen? Java Basics - Anfänger-Themen 7
S Wie kann ich bei diesem Code erreichen, das als Ergebnis hier 15 herauskommt? Java Basics - Anfänger-Themen 23
N Kann man den Code vereinfachen? Java Basics - Anfänger-Themen 25
marcooooo Code erklären Java Basics - Anfänger-Themen 28
marcooooo Code erklären Java Basics - Anfänger-Themen 4
S Advent of Code Day4 Java Basics - Anfänger-Themen 4
B Nach eingefügtem Code erkennt Compiler keine Instanzvar und meldet SyntaxError Java Basics - Anfänger-Themen 2
Gaudimagspam Caesars Code entziffern in Java Java Basics - Anfänger-Themen 8
Lukasbsc Wie kann ich meinen Code optimieren? Java Basics - Anfänger-Themen 4
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
I Input/Output Code wird doppelt ausgeführt Java Basics - Anfänger-Themen 3
T Main startet nicht bei vorgegebenen Code Java Basics - Anfänger-Themen 41
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
J Fehler im Code, aber ich weiß nicht wieso! Java Basics - Anfänger-Themen 6
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
M Code nur für Cracks? Crack the Passwort Übung Java Basics - Anfänger-Themen 7
parrot Code entferneJedeZweiteZiffer Java Basics - Anfänger-Themen 6
G Code kürzen Java Basics - Anfänger-Themen 5
Bluedaishi Source Code Signieren Java Basics - Anfänger-Themen 22
L Best Practice Code Refactoring für Methoden mit fast gleicher Aufbau Java Basics - Anfänger-Themen 6
L Best Practice Code refactern Java Basics - Anfänger-Themen 30
G code kürzen Java Basics - Anfänger-Themen 16
A Code umschreiben Java Basics - Anfänger-Themen 6
Torsten.E JavaFX mit Visual Studio Code verwenden Java Basics - Anfänger-Themen 1
C Beispiel-Code mit Pair wird nicht compiliert. Java Basics - Anfänger-Themen 8
X Reverse algorithm engineering (Java code) Java Basics - Anfänger-Themen 6
T Bufferedwriter code Nullpointerexception Java Basics - Anfänger-Themen 4
V Switch Methode macht Code kaputt Java Basics - Anfänger-Themen 18
R Was muss ich an meinem Code ändern? Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben