Code kürzen

Jonsered

Mitglied
Hallo Leute, ich habe ein Programm ( Hausaufgabe ) erstellt und es macht, was es soll

Aber ... ;)

Kann man den Code nicht irgendwie kürzen? Ich wiederhole mich sehr oft, zB oft den gleichen System.out.printl Text...

Fällt euch sonst noch was auf, wie man das ganze "optimieren" könnte? Super wäre es, wenn ihr den Code gleich mit rein schreibt, ich lerne einfacher und besser, wenn ich es sehe und dann auf ein andere Bsp anwende.

Vielen Dank

Java:
public class Bsp03 {

   static double flaeche;
   static final double PI = 3.141592653589793;
   static boolean leapYear;

   public static void main(String[] args) {
   
      int inMenue;
      int year;
      int n;
      double inRadius;
      
      System.out.println ("Please choose calculation");
      System.out.println ("1. Calculate circle area");
      System.out.println ("2. Leap year calculation");
      System.out.println ("3. Calculate next N leap years");
      System.out.println ("0. Exit");
   
      inMenue = SavitchIn.readLineInt();
   
      while ( inMenue != 0 ) {
      
         if ( inMenue < 0 || inMenue > 3 ) { // Eingabe wird ueberprueft
            System.out.println ("Invalid choice!");
            System.out.println ();
            System.out.println ("Please choose calculation");
            System.out.println ("1. Calculate circle area");
            System.out.println ("2. Leap year calculation");
            System.out.println ("3. Calculate next N leap years");
            System.out.println ("0. Exit");
         
            inMenue = SavitchIn.readLineInt();     
         }
      
         if ( inMenue == 1 ) {
            System.out.println ("Please enter circle radius:");
            inRadius = SavitchIn.readLineDouble();
            getCircleArea(inRadius);
            System.out.println ("Circle area is: " + flaeche);
            System.out.println ();
            System.out.println ("Please choose calculation");
            System.out.println ("1. Calculate circle area");
            System.out.println ("2. Leap year calculation");
            System.out.println ("3. Calculate next N leap years");
            System.out.println ("0. Exit");
         
            inMenue = SavitchIn.readLineInt();
         }
      
         if ( inMenue == 2 ) {
            System.out.println ("Please enter year:");
            year = SavitchIn.readLineInt();
            isLeapYear(year);
         
            if ( leapYear == true ) {
               System.out.println ( year + " is a leap year");
            }
            
            else {
               System.out.println ( year + " is not a leap year");
            }
         
            System.out.println ();
            System.out.println ("Please choose calculation");
            System.out.println ("1. Calculate circle area");
            System.out.println ("2. Leap year calculation");
            System.out.println ("3. Calculate next N leap years");
            System.out.println ("0. Exit");
         
            inMenue = SavitchIn.readLineInt();                 
         }
      
         if ( inMenue == 3 ) {
            System.out.println ("Please enter year:");
            year = SavitchIn.readLineInt();
            System.out.println ("How many leap years should be calculated:"); 
            n = SavitchIn.readLineInt();
            getNextLeapYears(year, n);
            System.out.println ();
            System.out.println ();
            System.out.println ("Please choose calculation");
            System.out.println ("1. Calculate circle area");
            System.out.println ("2. Leap year calculation");
            System.out.println ("3. Calculate next N leap years");
            System.out.println ("0. Exit");
            
            inMenue = SavitchIn.readLineInt();
         }
      }   
   
   }

// Methoden

   public static double  getCircleArea (double radius) {
      flaeche = PI * radius * radius;
      return flaeche;
   }
   
   public static boolean isLeapYear(int year) {
      if (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)) {
         leapYear = true;
      }
      
      else {
         leapYear = false;
      }   
   
      return leapYear;
   }   
   
   public static void getNextLeapYears(int year, int n) {
      int i = 0;
      
      while (i < n) {
         isLeapYear(year);
         
         if (leapYear == true) {
            System.out.print ( year + " ");
            i++;
         }
            
         year++;
      }
   }
     
}
 

Joose

Top Contributor
Java:
         isLeapYear(year);
         if (leapYear == true) {

Die Methode "isLeapYear" gibt dir ein boolean zurück, dieses wird von dir aber nirgends gespeichert.
Entweder entfernst du den Rückgabewert oder du speicherst den Rückgabewert und verwendest diesen.

Ansonsten ist anzumerken: Eine if-Abfrage erwartet einen boolschen Wert -> true oder false. leapYear ist boolscher Wert, dieser kann nur true oder false sein.
Eine extra Prüfung auf "leapYear == true" ist unnötig. Willst du auf "false" prüfen verwende "!leapYear".

Java:
if(leapYear == true) {
}
....
// Die Prüfung auf == true ist hier unnötig
if(leapYear) {
}
....
// Die Methode "isLeapYear()" gibt dir ein boolean zurück dieses kannst du auch gleich zur auswertung verwenden
if(isLeapYear(year)) {
}

In jeder if-Abfrage fragst du den User ob er nochmal etwas berechnen will. Das könntest du auch ans Ende der Schleife verschieben und statt 4x nur 1x stehen haben
 
Zuletzt bearbeitet:

chuxXo

Bekanntes Mitglied
Anstatt deinen ganzen "if (inMenue == ***) könntest du die kontrollstruktur "switch" verwenden.

Java:
if (inMenue != 0){
     switch (inMenue){
     case 1: break;
     ..........
     }
}
 
Zuletzt bearbeitet:

Joose

Top Contributor
Anstatt deinen ganzen "if (inMenue == ***) könntest du die kontrollstruktur "switch" verwenden.

Worin besteht der Vorteil eines switch gegenüber der if/else Anweisungen? Bzw. inwiefern würde dies den Code kürzen?
Ein switch hat schon seine Berechtigung, aber ich würde ein if/else einen switch immer vorziehen.


EDIT:
Wenn du den Code auch besser formtierst sparst du ebenfalls Zeilen:

Java:
if (Anweisung) {
 ....
} else if (...) {
 ....
} else {
 ....
}
 
Zuletzt bearbeitet von einem Moderator:

Thallius

Top Contributor
Alles was man öfter als zwei mal benötigt sollte man in eigene Methoden auslagern. In Deinem Beispiel kannst du z.B. die ganze Eingabe der Zahl mit all Ihren print() in eine eigeneMethode stecken und diese aufrufen.

Gruß

Claus
 

chuxXo

Bekanntes Mitglied
Worin besteht der Vorteil eines switch gegenüber der if/else Anweisungen? Bzw. inwiefern würde dies den Code kürzen?
Ein switch hat schon seine Berechtigung, aber ich würde ein if/else einen switch immer vorziehen.
[/code]

Bin davon ausgegangen, dass es switch nicht umsonst gibt und eigentlich für solche Fälle dann ja perfekt zu verwenden ist. Och Joose, du hast immer ein Gegenargument :D

Das was mir noch auffällt, ist, dass du deine Variablen zusammen erstellen könntest. Durch Kommas getrennt. Und statt den ganzen println könntest du ein printf verwenden. :)

EDIT:
Aber warum sollte man if vorziehen ? :)
 
Zuletzt bearbeitet:

Joose

Top Contributor
Bin davon ausgegangen, dass es switch nicht umsonst

Stimmt, switch gibt es auch nicht umsonst

Das was mir noch auffällt, ist, dass du deine Variablen zusammen erstellen könntest.

Wäre natürlich auch möglich, aber wozu? Hier sparst du wirklich nur "Platz" aber machst vielleicht den Code unübersichtlicher.
Also immer abwegen ob man es machen sollte oder nicht.

Aber warum sollte man if vorziehen ? :)

Der Vorteil eines if liegt darin das leichter Fehler vermieden werden ;)
Vor allem bei Anfänger wird beim "switch" immer wieder mal das "break;" vergessen und plötzlich führt der Code etwas aus was er nicht tun sollte.

In diesem Fall macht es keinen großen Unterschied ob switch oder if/else ;) , aber persönlich ziehe ich ein if/else switch vor :)
 

Flown

Administrator
Mitarbeiter
So ich habe das Bedürfnis meinen Senf auch dazuzugeben.

Also die switch vs. if-else Konstrukt Diskussion ist Geschmacksache. Aber ich würde hier auch ein switch vorziehen, denn in den Tutorials steht:

Deciding whether to use if-then-else statements or a switch statement is based on readability and the expression that the statement is testing. An if-then-else statement can test expressions based on ranges of values or conditions, whereas a switch statement tests expressions based only on a single integer, enumerated value, or String object.

Also nachdem ich keine Ranges prüfen will, ist switch die richtige Wahl.

Java:
import java.util.Arrays;
import java.util.Scanner;

public class Bsp03 {
  
  public static void main(String[] args) {
    
    try (Scanner scanner = new Scanner(System.in)) {
      int inMenue;
      do {
        printMenu();
        inMenue = scanner.nextInt();
        switch (inMenue) {
          case 0:
            break;
          case 1:
            handleCircleArea(scanner);
            break;
          case 2:
            handleLeapYear(scanner);
            break;
          case 3:
            handleLeapYearList(scanner);
            break;
          default:
            System.out.println("Invalid choice!");
            System.out.println();
            break;
        }
      } while (inMenue != 0);
    }
  }
  
  private static void printMenu() {
    System.out.println("Please choose calculation");
    System.out.println("1. Calculate circle area");
    System.out.println("2. Leap year calculation");
    System.out.println("3. Calculate next N leap years");
    System.out.println("0. Exit");
  }
  
  private static void handleCircleArea(Scanner scanner) {
    double inRadius;
    System.out.println("Please enter circle radius:");
    inRadius = scanner.nextDouble();
    System.out.println("Circle area is: " + getCircleArea(inRadius));
    System.out.println();
  }
  
  private static void handleLeapYear(Scanner scanner) {
    System.out.println("Please enter year:");
    int year = scanner.nextInt();
    
    System.out.println(year + " is " + (isLeapYear(year) ? "" : "not ") + "a leap year");
    System.out.println();
  }
  
  private static void handleLeapYearList(Scanner scanner) {
    System.out.println("Please enter year:");
    int year = scanner.nextInt();
    System.out.println("How many leap years should be calculated:");
    int n = scanner.nextInt();
    System.out.println(Arrays.toString(getNextLeapYears(year, n)));
    System.out.println();
  }
  
  // Methoden
  public static double getCircleArea(double radius) {
    return Math.PI * radius * radius;
  }
  
  public static boolean isLeapYear(int year) {
    return year % 4 == 0 && (year % 100 != 0 || year % 400 == 0);
  }
  
  public static int[] getNextLeapYears(int year, int n) {
    int[] leapYears = new int[n];
    int i = 0;
    while (i < n) {
      if (isLeapYear(year)) {
        leapYears[i++] = year;
      }
      year++;
    }
    return leapYears;
  }
}
 
Zuletzt bearbeitet:

chuxXo

Bekanntes Mitglied
Wäre natürlich auch möglich, aber wozu? Hier sparst du wirklich nur "Platz" aber machst vielleicht den Code unübersichtlicher.
Also immer abwegen ob man es machen sollte oder nicht.

Das stimmt. Aber wenn ich es so mach sieht das ganze dann folgendermaßen aus:
Java:
int variable1 = 0,
    variable2 = 1,
    variable3 = 2;

Wie sieht es da Perfomancetechnisch aus ? Bin mir sicher, dass es nicht spürbar sein wird, aber eigentlich müsste es so schneller sein, oder? Er hat ja so einen Schritt weniger.

Und switch und if ist in dem Fall Geschmackssache.
Immer gut, neue Dinge zu erfahren ;)
 

Jonsered

Mitglied
Hey Leute, vielen Dank!

Also das mit switch möchte ich noch nicht machen, da wir das auch noch nicht um Unterricht hatten :)

@ Joose: Wie würdest du den Code dann schreiben, bin gerade ein wenig verwirrt , speziell mit Anfang und Ende

Oder besser als Methode, nur wie macht man da eine gaze Textausgabe?

Ich danke euch!!!
 

arilou

Bekanntes Mitglied
Zusätzliche Methode
Java:
void showOptions() {
  System.out.println ("Please choose calculation");
  System.out.println ("1. Calculate circle area");
  System.out.println ("2. Leap year calculation");
  System.out.println ("3. Calculate next N leap years");
  System.out.println ("0. Exit");
}
Und die rufst du auf, überall dort, wo die obigen Zeilen dafür wegfallen können.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Code kürzen Java Basics - Anfänger-Themen 5
G code kürzen Java Basics - Anfänger-Themen 16
F Code kürzen Java Basics - Anfänger-Themen 9
E Interface einfügen und Code kürzen Java Basics - Anfänger-Themen 15
U Code kürzen Java Basics - Anfänger-Themen 4
tomzen Programm ignoriert in der Ausführung Code Java Basics - Anfänger-Themen 8
O Obfuscateter Code lässt sich nicht ausführen? Java Basics - Anfänger-Themen 7
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
L Ist der Code richtig Java Basics - Anfänger-Themen 3
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
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
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

Ähnliche Java Themen

Neue Themen


Oben