OOP Designrichtlinie Parameter Prüfung

Skrodde

Aktives Mitglied
Hallo zusammen,
in meinem aktuellen Projekt habe ich mehrere Klassen, die sich hierarchisch erzeugen und aufrufen. Meine Frage ist nun: Wenn ich quasi auf der untersten Ebene Restriktionen an einen Parameter habe, gibt es dann Richtlinien, wie die Gültigkeit dieses Parameters überprüft werden soll?
Beispiel:
Java:
class Polynomial {
    private Term term;

    public Polynomial() {
        term = new Term(0.5,0.1);
    }
}
Java:
class Term {
    private double coefficient;
    private int exponent;

    public Term(double coef, int exp) {
        this.coefficient = coef;
        this.exponent = exp;
    }
}
Dieses Konstrukt führt zu einem Fehler, da der übergebene zweite Wert bei der Instanziierung von Term kein Integer ist. Die Frage nun: Sollte die Klasse Polynomial überprüfen, dass sie Term korrekt instanziiert, oder sollte Term eher eine Exception schmeißen, die Polynomial dann verarbeiten muss?
Gibt es hierzu Richtlinien?
Danke für die Hilfe,
Gruß, Skrodde
 
S

SlaterB

Gast
es gibt da verschiedene Ebenen zu betrachten, es nicht etwas unklar war du meinst

der Compiler prüft diese Verträglichkeit bereits, du hast gar keine Chance selber irgendwas zu überlegen,

wie stellst du dir etwa 'sollte Term eher eine Exception schmeißen' vor?
wie soll Term überhaupt drankommen um zu entscheiden, soll in der int-Variable ein double-Wert vorgefunden werden?
das widerspricht doch allen Regeln, es gibt keine Prüfmethode 'ist in dieser int-Variablen auch ein int oder zufällig eine ArrayList?'


solche Fragen stellen sich eher nur in Programmen, die den ganzen Komfort der Sprache ignorieren und nur Object oder gar Listen von Object als Parameter verwenden,
dann kann sicherlich beliebiges übergeben und an beliebigen Stellen geprüft werden, geht deine Frage wirklich dorthin?
 
Zuletzt bearbeitet von einem Moderator:
B

bygones

Gast
die Frage ist warum erzeugt die eine Klasse eine Instanz der anderen Klasse und bekommt diese nicht injected ?
 
S

SlaterB

Gast
@bygones
ein Objekt einer Klasse A darf kein Objekt einer Klasse B erzeugen?
kann man irgendwie anders als Trollen verstehen?
 

Skrodde

Aktives Mitglied
Hallo zusammen und vielen Dank für die Antworten soweit,
mein Beispiel war wohl zu simpel gewählt. Es geht mir mehr darum, dass Parameter übergeben werden, die dann Anforderungen erfüllen müssen, als das Parameter eines falschen Typs übergeben werden.
Konkret darf der Exponent bei mir zum Beispiel nicht negativ sein, da der Term ja ein Polynom definiert. Ich habe das oben mal geändert. EDIT: (UPS, ich dachte, es gäbe hier einen "editieren" Button für Beiträge, gibt es wohl aber nur für den letzten abgegebenen?)
Die BeanValidation klingt nett, aber soweit ich das gesehen habe, wendet sich das doch eher an Web-Anwendungen? Ich schriebe aber gerade eine Desktop-Anwendung, kann man die Beans da auch benutzen?
Die grundsätzliche Frage ist halt, ob eher die Klasse Term für die Überprüfung der Einhaltung des Wertebereichs zuständig ist oder ob das auch in Oberklassen ausgelagert werden kann? Ich dachte, da gäbe es vielleicht eine Richtlinie à la: "Variablenbereich immer in kleinst / größt möglichst granularer Klasse checken" oder so.
Gruß, Skrodde
 
B

bygones

Gast
@bygones
ein Objekt einer Klasse A darf kein Objekt einer Klasse B erzeugen?
kann man irgendwie anders als Trollen verstehen?
in keiner weise:

Flaw: Constructor does Real Work

oder prinzipiell - Tell, dont ask

es mag bei einem simplen Value object nicht sehr ins gewicht fallen, aber wenn hier anscheinend Pruefungen vorgenommen werden muessen koennte das dann eben schon wichtig sein

Die grundsätzliche Frage ist halt, ob eher die Klasse Term für die Überprüfung der Einhaltung des Wertebereichs zuständig ist oder ob das auch in Oberklassen ausgelagert werden kann? Ich dachte, da gäbe es vielleicht eine Richtlinie à la: "Variablenbereich immer in kleinst / größt möglichst granularer Klasse checken" oder so.
Gruß, Skrodde
Natuerlich sollte nur derjenige den Test machen der das Wissen dazu hat. Wenn die Term Klasse an sich sagen kann ob sie valide ist, dann soll nur sie das tun. Wenn aber der Kontext entscheidend ist, dann muss der Kontext dies tun - in deinem Fall das Polynom.
 
Zuletzt bearbeitet von einem Moderator:

Skrodde

Aktives Mitglied
Natuerlich sollte nur derjenige den Test machen der das Wissen dazu hat. Wenn die Term Klasse an sich sagen kann ob sie valide ist, dann soll nur sie das tun. Wenn aber der Kontext entscheidend ist, dann muss der Kontext dies tun - in deinem Fall das Polynom.

Okay, das ist eine zufriedenstellende Antwort, die ich in meinem Projekt umsetzen kann. Vielen Dank an alle für die Hilfe :toll:
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F KI / Machine Learning Parameter verschachtelte for Schleifen Allgemeine Java-Themen 2
F KI / Machine Learning Parameter verschachtelte for Schleifen Allgemeine Java-Themen 1
8u3631984 Funktions Parameter mit Lombok "NonNull" annotieren wird in Jacococ Testcoverage nicht herausgefiltert Allgemeine Java-Themen 3
JavaJüngling beliebige Collection die Comperable Elemente enthält als Parameter Allgemeine Java-Themen 37
M Datensatz auf ein bestimmten Parameter einzugrenzen Allgemeine Java-Themen 11
B JAX - RS.... Multiple parameter application/x-www-form-urlencoded.... Allgemeine Java-Themen 6
B Parameter Konstruktor plus rechnen Allgemeine Java-Themen 6
L Die abzuleitende Klasse als Parameter übergeben Allgemeine Java-Themen 4
W Haben Konstruktoren in Java eigentlich immer mindestens einen Parameter? Allgemeine Java-Themen 4
I Array Parameter mit 2 Klassen - NullPointerException Allgemeine Java-Themen 3
F URI mit Parameter klappt nicht Allgemeine Java-Themen 1
H Aufruf eines Web Service anhand übergebenen Parameter Allgemeine Java-Themen 2
temi best practice: Parameter überprüfen, wo? Allgemeine Java-Themen 9
S Parametrisierte jUnit 5-Tests mit eigenen Datentypen/Klassen-Objekten als Test-Parameter Allgemeine Java-Themen 0
MiMa If-Abfrage mit Parameter Allgemeine Java-Themen 8
I Javaaufruf aus Batch inkl. Parameter (Adminrechte) Allgemeine Java-Themen 2
P Java https proxy (-Dhttps.proxyHost) Start-Parameter funktioniert nicht? Allgemeine Java-Themen 2
Neumi5694 Methoden Generic: Rückgabetyp als Class-Parameter übergeben Allgemeine Java-Themen 3
K Java FX Zu startenden FXML-Controller per Parameter wählen Allgemeine Java-Themen 2
F Enum-werte als Methoden-Parameter übergeben Allgemeine Java-Themen 6
T Klassen Parameter weitergabe Allgemeine Java-Themen 1
C Überschreiben mit kontravariante Parameter Allgemeine Java-Themen 13
M Parameter auslesen im Servlet Allgemeine Java-Themen 0
perlenfischer1984 Wann ist ein Parameter Check sinnvoll Allgemeine Java-Themen 7
Neumi5694 Vererbung Parameter muss 2 Bedingungen erfüllen Allgemeine Java-Themen 2
Sogomn Methode als Parameter? Allgemeine Java-Themen 3
T Parameter Allgemeine Java-Themen 6
R Parameter Adapter - Design Allgemeine Java-Themen 1
I Methode verallgemeinern (Methode als Parameter)? Allgemeine Java-Themen 10
F In OSX: Java-Programm über URI-Scheme aufrufen mit Parameter? Allgemeine Java-Themen 0
H Generics als Parameter Allgemeine Java-Themen 1
N [stream-api] Parameter pro Typ zählen Allgemeine Java-Themen 1
OnDemand Maximale Parameter Allgemeine Java-Themen 5
M final vor dem parameter eines Konstruktors Allgemeine Java-Themen 1
S Servlet, per URLConnection Mit String Http Parameter mitsenden Allgemeine Java-Themen 3
M Parameter-Datei einlesen (zeilenweise); Dateiintegrität Allgemeine Java-Themen 7
H JasperReport: Parameter befüllen Allgemeine Java-Themen 7
Joew0815 JList + JTableModel: Parameter der Tabelle übergeben Allgemeine Java-Themen 10
Y Applet/Html - Wie Java-Methode aufrufen, die einen Parameter erwartet? Allgemeine Java-Themen 3
G Polymorphie Funktion als Parameter Allgemeine Java-Themen 8
G Methoden Unterschiedliche viele Parameter Allgemeine Java-Themen 17
F Parameter im Link /jar-Aufruf Allgemeine Java-Themen 12
C char und char-Array als parameter übergeben Allgemeine Java-Themen 6
B Array Parameter Problem Allgemeine Java-Themen 3
C Reflektions, Benutzer soll Konstruktor auswählen und Parameter übergeben können Allgemeine Java-Themen 5
S Keytool: mögliche Werte für Parameter Allgemeine Java-Themen 4
H Externes Programm, Parameter Allgemeine Java-Themen 6
C Webservice: XML Parameter übergabe. Allgemeine Java-Themen 7
M Session-Parameter setzen? Allgemeine Java-Themen 10
P VM-Parameter -D... Allgemeine Java-Themen 3
V Wildcard aus Parameter in return type Allgemeine Java-Themen 2
O Collections Eigene Methodenzusicherung bei Collections als Parameter Allgemeine Java-Themen 2
W ScriptEngine + Wie Parameter übergeben bei Fukntion? Allgemeine Java-Themen 2
A Reflection Konstruktor Parameter Supertyp Allgemeine Java-Themen 2
F Parameter für Java Applikation per xml ins Meta-inf speichern? Allgemeine Java-Themen 3
J BlueJ Methode hat zu viele Parameter Allgemeine Java-Themen 6
R VM-Error - BadWindow (invalid Window parameter) Allgemeine Java-Themen 4
J Parameter an Java übergeben Allgemeine Java-Themen 10
S Neue Instanz eines Objekts erzeugen - Konstruktor erhaelt Parameter. Allgemeine Java-Themen 5
P VM Parameter und .jar Allgemeine Java-Themen 3
L Parameter-Objekte verändern oder nicht? Allgemeine Java-Themen 6
J Parameter absichtlich für außen verändern Allgemeine Java-Themen 4
A wie kann man Parameter an ein Task übergeben? Allgemeine Java-Themen 3
Iron Monkey Singleton mit Parameter Allgemeine Java-Themen 14
G setter und getter: Parameter Überprüfung Allgemeine Java-Themen 6
G JVM Parameter Allgemeine Java-Themen 7
G Parameter Bedeutung Allgemeine Java-Themen 4
W Properties-Klasse: mehrere Parameter-Belegungen übergeben? Allgemeine Java-Themen 2
J Unicode: cmd parameter (main args); exec params; filenames Allgemeine Java-Themen 2
C US_export_policy.jar und local_policy.jar VM Parameter Allgemeine Java-Themen 1
J Casten ueber generischen Parameter? Allgemeine Java-Themen 5
T Parameter einer Klasse auf Interface prüfen Allgemeine Java-Themen 6
G generische Klasse als Parameter einer generischen Klasse Allgemeine Java-Themen 5
G Parameter oder Attribut (wann nehme ich was?) Allgemeine Java-Themen 12
S .rar-Dateien ein Passwort als Parameter übergeben Allgemeine Java-Themen 5
N Funktion als Parameter einer anderen Funktion Allgemeine Java-Themen 5
D Parameter parsen? Allgemeine Java-Themen 15
G Typ Parameter & Reflections Allgemeine Java-Themen 4
F mehrere Verzeichnisse als Parameter Allgemeine Java-Themen 15
Y Javadoc - Wie Parameter ansprechen bei Methodenkommentar Allgemeine Java-Themen 2
G Parameter bei mailto Allgemeine Java-Themen 2
C Java Parameter zum starten ohne auf Programmende zu warten Allgemeine Java-Themen 4
V Jar Datei mit Parameter starten Allgemeine Java-Themen 7
P Übergabe- Parameter SQL Map Allgemeine Java-Themen 45
S URL-Parameter auslesen Allgemeine Java-Themen 2
F Parameter vs Argument Allgemeine Java-Themen 4
T xverify-parameter : Workaround zur Laufzeit? Allgemeine Java-Themen 8
F Viele generische Parameter sinnvoll? oder besser casten? Allgemeine Java-Themen 10
P command line parameter auswerten Allgemeine Java-Themen 3
M Parameter an main übergeben aber wie? Allgemeine Java-Themen 4
T Parameter an Thread übergeben Allgemeine Java-Themen 8
S synchronisation einer Methode abhängig vom Parameter Allgemeine Java-Themen 10
J Interface als Parameter übergeben Allgemeine Java-Themen 4
L JNI: C-->Java : Methode mit String-Parameter Allgemeine Java-Themen 18
A Weshalb man Parameter auf Gültigkeit prüfen sollte Allgemeine Java-Themen 6
H in JOE die Parameter -xmx256m -xrs hinzufügen Allgemeine Java-Themen 2
K Testen einer Klasse mit File Objekt als Parameter Allgemeine Java-Themen 6
X Default-Werte für Methoden-/Funktions-Parameter Allgemeine Java-Themen 2
M Funktion als Parameter oder andere Möglichkeit Allgemeine Java-Themen 3
R Parameter in einer Methode verändern Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben