Funktion hier sinnvoll ?

Status
Nicht offen für weitere Antworten.

sowieso

Aktives Mitglied
Hi !

Ich hab mal eine allgemeine Frage, wann man Funktionen einsetzt.

Sagen wir, wir haben eine HashMap <String,Integer> die schon mit mehreren Map.Entrys gefüllt ist. In einer Funktion start() werden je nach Situation (hängt vom Zustand von Variablen einer anderen instantiierten Klasse ab) bestimmte Map.Entrys aus der HashMap entfernt.

Folgender Code dient nur als Skizze und ist nicht korrekt:

Code:
public void start()
{
    HashMap <String,Integer> map = reader.data();
    
    for(int i=0; i<panel.size(); i++)
    {  
        if (panel.checked(i))
        {
            HashMap.remove(panel.getKey(i));
        }
    }   
}


Wäre jetzt folgender Code besser ? -->

Code:
public void start()
{
    HashMap <String,Integer> map = reader.data();
    
    map = adjustMap(map);    
}

private HashMap<String,Integer> adjustMap(HashMap<String,Integer> map)
{
    for(int i=0; i<panel.size(); i++)
    {  
        if (panel.checked(i))
        {
            map.remove(panel.getKey(i));
        }
    }
    return map;
}



Also durch verwendung einer Funktion wird der Code in der Funktion start() ja übersichtlicher. Andererseits erspart die Funktion ja keinen Code. Und kann auch nur einmal für start() verwendet werden...

Würdet ihr sagen, dass letzteres oder ersteres besser ist ?
 

sliwalker

Top Contributor
Hoi,

prinzipiell würde ich dazu sagen, dass man Aufgaben in Funktionen bzw. Methoden auslagert, wenn

a) es dazu beiträgt den Code leserlicher zu machen
b) man dadurch logisch getrennte Bereiche auch "physikalisch" trennt
c) man Teilbereiche einer "großen" Aufgabe noch an anderer Stelle wiederverwenden/aufrufen möchte.


Bsp: Eine Passworteingabe muss überprüft werden auf:
- formale Korrektheit (mind. eine Ziffer)
- andere Sicherheitskriterien (muss sich von den letzten drei Passwörtern unterscheiden)

Man kann das jetzt alles in eine Methode haun:

Code:
public boolean checkPassword(String strPassword)
{
    if (strPassword hat eine Ziffer)
    {
         if (strPassword unterscheidet sich von den letzten drei PW)
         {
              return (true);
          }
    }
    return (false);
}

Was aber, wenn an einer anderen Stelle nochmal überprüft werden soll, ob ein Passwort formal korrekt ist?

...es muss halt Sinn machen...

Bei Deinem Problem musst Du abschätzen, ob adjustMap und start() IMMEr zusammengehören. Wenn ja, nicht auslagern.

greetz
SLi
 
G

Guest

Gast
Hallo

Als Ergaenzung zum Vorgaenger:

1. Immer eine Methode erstellen, wenn der Code "zu lang" wird. Sprich spaetestens wenn man scrollen muesste!

2. Gut strukturieter Code hilft sinnlose Kommentare zu vermeiden. Sprich immer wenn du meinst einen Kommentar in deinen Code schreiben zu muessen; Ueberleg erstmal, ob du nicht durch eine bessere Strukturierung und bessere Benennung den Kommentar sparen kannst.

3. Den "Schleifenkoerper" kann man fast immer in eine Methode auslagern. Dadurch muss der Leser nicht mehr den Code verstehen, sondern kann sich direkt auf die fachlichen Aufgaben konzenrieren.

Auf dein Beispiel angewendet:

Code:
public void start() 
{ 
    HashMap <String,Integer> map = reader.data(); 
    
    for(int i=0; i<panel.size(); i++) 
    {  
        removeCheckedPanel(map,panel.getKey(i))
    }    
}

private void removeCheckedPanel(Map map,String key) { // dir faellt sicher ein besserer Name ein
        if (panel.checked(i)) 
        { 
            map.remove(key); 
        } 
}

Vielleicht noch besser:
Code:
public void start() 
{ 
    HashMap <String,Integer> map = reader.data(); 
    checkPanel(panel,map);  
}

private void checkPanel(Panel panel,Map map) {
    for(int i=0; i<panel.size(); i++) 
    {  
        removeCheckedPanel(map,panel.getKey(i))
    }  
}

private void removeCheckedPanel(Map map,String key) {
        if (panel.checked(i)) 
        { 
            map.remove(key); 
        } 
}

Anmerkung:
- Fuer Syntaxfehler uebernehme ich keine Haftung ...
Vorteile:
- Derjenige der sich die Methode start anschaut sieht relativ schnell was fachlich passeiren soll.
- wenn er taetsaechlich mal nachschauen will sieht er in checkPanel sofort was fachlich passiert. Schleife und fachlich removeCheckedPanel. Ohne den Code weiter anschauen zu muessen...

Die Implementierung dieser Struktur dauert uebrigens fuer geuebte Entwickler etwa eine Minute laenger. Sprich auch kein wesentlicher Zeitverlust. Aber ein enomer Qualitaetsgewinn.
 
G

Gast

Gast
Es sind noch mindestens zwei weitere Punkte erwähnenswert.
Wenn ein Teil mehrfach Programmiert werden müßte. Ein Block oder eine Reihe von Befehlen kommt gleich in mehreren verschiedenen Methoden vor, bzw. mehrfach in einer Funktion, so kann man diesen redundanten Teil in eine Funktion auslagern und muß sich dann nur um diese eine Codestelle kümmern. Also wenn man diese Codestelle später ändern möchte.

Das zweite wäre die Testbarkeit. Beim Testen sollte die zu testende Klasse unverändert bleiben. Sprich es sollten keine extra Debuggingmessages etc. eingesetzt werden usw. Hat man nun feiner granulierte Methoden, kann man auch viel feiner testen. Eine Codestelle, die früher in einer Riesigen Funktion versteckt ist, kann so leicht zugänglich und gut testbar werden.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
E Hilfe bei rekursiver Funktion Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
M Eine Funktion zuweisen Java Basics - Anfänger-Themen 3
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
M variable in anderer funktion aufrufen Java Basics - Anfänger-Themen 10
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
W GUI - JButton ohne Funktion? Java Basics - Anfänger-Themen 24
J Rekursive Funktion und return statement Java Basics - Anfänger-Themen 3
F Wie kann ich eine Funktion schreiben, die nur in bestimmten Fällen einen Wert zurückgibt? Java Basics - Anfänger-Themen 5
R Buttons ohne Funktion Java Basics - Anfänger-Themen 2
I Generische Funktion Java Basics - Anfänger-Themen 3
E Pervasive PSQL insert funktion geht nicht Java Basics - Anfänger-Themen 9
C Java Funktion: externe Daten vom Internet einbinden Java Basics - Anfänger-Themen 2
T Log Funktion erstellen Java Basics - Anfänger-Themen 1
M Wie kann ich eine Methode aus einem Interface in eine Klasse implementieren, so dass sie ihre Funktion ausführt? Java Basics - Anfänger-Themen 7
H Den Wert einer rekursiven Funktion bestimmen Java Basics - Anfänger-Themen 5
J In main() Datei geöffnet, von anderer Funktion beschreiben Java Basics - Anfänger-Themen 3
M toDouble Funktion Java Basics - Anfänger-Themen 3
Tino1993 Ellipse über draw Funktion ohne spur wandern lassen Java Basics - Anfänger-Themen 6
X Ackermannsche Funktion Java Basics - Anfänger-Themen 32
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
P Dezimal zu Hexadezimalzahl Funktion Java Basics - Anfänger-Themen 5
S Verwenden von throw Exception an der Funktion Java Basics - Anfänger-Themen 2
M Arrays in Funktion Kopieren und Bearbeiten Java Basics - Anfänger-Themen 4
B Funktion mit mehreren Rückgabewerten aka Prozeduren? Java Basics - Anfänger-Themen 12
J Dynamisches Array durch split()-Funktion? Java Basics - Anfänger-Themen 3
D Funktion nur 1 Rueckgabewert Java Basics - Anfänger-Themen 9
M Wie lang eine Funktion/Methode? Java Basics - Anfänger-Themen 51
N den inhalt eines array per funktion ausgeben Java Basics - Anfänger-Themen 8
R Ackermann Funktion Java Basics - Anfänger-Themen 2
B Treetable (rekursive Funktion) aufbauen von Datenbank Java Basics - Anfänger-Themen 4
D Funktion zwei Arraylisten zu verleichen ob gleich funktioniert nicht Java Basics - Anfänger-Themen 26
N Abfragen eines Textes aus einem JTextField in Java, Funktion, CardLayout, Java Basics - Anfänger-Themen 2
T Rekursion Warum bricht meine Funktion nicht ab Java Basics - Anfänger-Themen 4
N Funktion funktioniert nicht immer Java Basics - Anfänger-Themen 6
E Contain-funktion überlisten Java Basics - Anfänger-Themen 4
J Division ohne Arithmetische Funktion Java Basics - Anfänger-Themen 2
S Funktion in Klasse auslagern Java Basics - Anfänger-Themen 4
J Problem mit Boolean bei Funktion! Java Basics - Anfänger-Themen 5
S Gibt es eine Funktion, die gewissermaßen eine Reihe von instanceOf() vereinheitlicht? Java Basics - Anfänger-Themen 19
D Nullstellen einer Funktion 3. Grades mit Horner Schema Java Basics - Anfänger-Themen 6
Aprendiendo Gibt es in der JAVA-API eine Funktion, die eine Dezimalzahl in eine binäre Zahl umwandelt? Java Basics - Anfänger-Themen 8
D Funktion gibt Dimension zurück Java Basics - Anfänger-Themen 11
A Rekursion Funktion in eine Iterativ Funktion umwandeln Java Basics - Anfänger-Themen 9
T static String Variable wird nur beim ersten aufruf durch eine Funktion geändert. Java Basics - Anfänger-Themen 16
B Zugriffe in einer Klasse / Funktion Java Basics - Anfänger-Themen 9
T Koordinatensystem zeichnen - Variablen merken? Quadratische Funktion zeichnen? Java Basics - Anfänger-Themen 5
J Array innerhalb einer Funktion mehrfach iniatilisieren Java Basics - Anfänger-Themen 4
T Lambda-Funktion bei Binärbäumen Java Basics - Anfänger-Themen 13
J Wie lässt sich der Konstruktor einer Klasse einer Funktion einer Klasse nutzen. Java Basics - Anfänger-Themen 4
M Thread.sleep() Funktion Java Basics - Anfänger-Themen 1
B OOP Wie benutze ich die Main Funktion richtig? Java Basics - Anfänger-Themen 10
H Nicht Static Funktion ohne Objekt aufrufen? Java Basics - Anfänger-Themen 6
K Methoden mit den Namen accept. Welche Funktion haben diese? Java Basics - Anfänger-Themen 2
E Compare-Funktion bei eigener Klasse Java Basics - Anfänger-Themen 4
S Threads run - Funktion wird nur einmal ausgeführt. Java Basics - Anfänger-Themen 8
B Anwender soll mathematische Funktion eingeben können, Einfachster Fnktionsplotter Java Basics - Anfänger-Themen 4
R If Funktion funktioniert nicht :P Java Basics - Anfänger-Themen 3
H Funktion in Hintergrund und Vordergrund ausführen Java Basics - Anfänger-Themen 11
S Funktion die mir fuer einen String eine Zahl zwischen 0.0 und 1.0 zurueckliefert..? Java Basics - Anfänger-Themen 9
S Funktion eines Stacks Java Basics - Anfänger-Themen 4
T Integer-Objekt über Hash-Funktion in Array ablegen Java Basics - Anfänger-Themen 1
S Separate Funktion für JUnit-Test Java Basics - Anfänger-Themen 3
D Keine Funktion bei "else" Java Basics - Anfänger-Themen 5
S timer funktion mit javax panel Java Basics - Anfänger-Themen 3
T Klassen Funktion in einem Funktionsaufruf definieren Java Basics - Anfänger-Themen 3
F Funktion eines JButton in einen Vektor verlagern Java Basics - Anfänger-Themen 4
X Eval-Funktion mit Variable Java Basics - Anfänger-Themen 2
T Screenreader Funktion Java Basics - Anfänger-Themen 2
S Wertetabelle einer Funktion f : R -> R Java Basics - Anfänger-Themen 1
P Methoden suche funktion die char wert ausgibt wenn man numerischen wert und radix angibt Java Basics - Anfänger-Themen 1
1 repaint() Funktion erzeugt Flackern Java Basics - Anfänger-Themen 33
J Taschenrechner Funktion Java Basics - Anfänger-Themen 18
R if funktion ohne else - Bedingung trifft nicht zu, ausgabe nicht nachvollziehbar Java Basics - Anfänger-Themen 7
shiroX OOP Java Funktion implementieren Java Basics - Anfänger-Themen 3
O Debug-Funktion mit Slick - Kleines Problem Java Basics - Anfänger-Themen 5
F Funktion immer zur vollen Stunde? Java Basics - Anfänger-Themen 3
S ResultSet close() in funktion nich möglich. Java Basics - Anfänger-Themen 8
C Meine erste Funktion Java Basics - Anfänger-Themen 12
J Funktion um JSON per Post senden/emfangen Java Basics - Anfänger-Themen 3
G OOP Aus Objekt auf Funktion der erzeuger Klasse zugreifen? Java Basics - Anfänger-Themen 11
D Binäre Suche für Integerarray in rekursiver Funktion Java Basics - Anfänger-Themen 5
M Interface als Konstruktorparameter nutzen, um Funktion zu plotten Java Basics - Anfänger-Themen 14
NR_EIGHT Benutzereingabe in Funktion verpacken Java Basics - Anfänger-Themen 4
J Funktion definieren und ausfuehren Java Basics - Anfänger-Themen 27
D Loop Funktion für Robot Klasse Java Basics - Anfänger-Themen 5
N mathematische Funktion Java Basics - Anfänger-Themen 29
R Programm verstehen, Funktion Java Basics - Anfänger-Themen 4
C Automatisches Ausfuehren einer Funktion beim Laden eines Jar files Java Basics - Anfänger-Themen 3
O Nicht Standard Form boolesche Funktion in Standard Form parsen Java Basics - Anfänger-Themen 3
F Sleep Funktion Java Basics - Anfänger-Themen 12
S Euklid Funktion Java Basics - Anfänger-Themen 8
H Funktion mit Argumenten Java Basics - Anfänger-Themen 5
Q Random Funktion JButtons Java Basics - Anfänger-Themen 6
O Probleme mit der repaint-Funktion Java Basics - Anfänger-Themen 6
F Eine Frage über paint() Funktion Java Basics - Anfänger-Themen 2
S Parameterübergabe - identische Funktionen, aber falsche Funktion Java Basics - Anfänger-Themen 5
C Probleme mit replaceAll Funktion Java Basics - Anfänger-Themen 9
S Vector mit beliebigen Klassen an Funktion übergeben Java Basics - Anfänger-Themen 20

Ähnliche Java Themen

Neue Themen


Oben