Lesbare args für die main-Methode

DaBe1812

Bekanntes Mitglied
Hi,
ich habe folgendes Problem:
wir haben eine Reihe von Programmen, die die Datenqualität einer Datenbank verbessern sollen. Diese laufen täglich, oder wöchentlich oder monatlich. Da haben sich im Laufe der Jahre mehrere Programme angesammelt.
Jetzt war es so, dass es eine Batch-Datei zu jedem Programm gab und diese dann in der Windows Tasksliste zeitlich gesteuert ausgeführt worden ist. Natürlich Nachts um keine Performance zu klauen. Da die Tools unterschiedlich lange dauern und teilweise aber auf dieselben Daten zugreifen, wurden die dann im Task-Planer mit unterschiedlichen Startzeiten geplant. Mal mit einer Stunde Zeit für aufwändigere Sachen und mal mit einer halben Stunde Zeit für nicht so aufwendige.
Nach den ganzen Überarbeitungen werden die Daten dann zu allem Überfluss auch noch exportiert und an eine andere Abteilung gesendet, damit diese auch Dinge mit den Daten tut. Problem war, dass die Nacht langsam aber sicher zu kurz geworden ist für die ganzen Tools, damit am nächsten Morgen der Export auch noch pünktlich raus geht.
Also bin ich jetzt hergegangen und habe alle Tools unter ein großes Tool gestellt, welches zu einer Zeit startet und die Tools einfach sequentiell abarbeitet, das spart einen Haufen Zeit, weil ich mir keine Puffer mehr planen muss, weil das Kontroll-Tool weiß ja, wann eins der kleinen Programme fertig ist und startet dann direkt das nächste.

Nun zu meiner Frage:
die Kontrolle, welches Tool gestartet werden soll und welches nicht, mache ich aktuell über ein Array von 0 und 1, welches ich als Argument mit übergebe. So kann ich mit einer Kombination aus Nullen und Einsen sowohl ein Tool alleine, als auch eine Gruppe von Tools starten.
Das funktioniert zwar, aber nur so lange, wie ich lebe. Das System ist von außen nicht wirklich wartbar, bzw. man kann nicht direkt sehen, was eine 1 an welcher Stelle macht.
Aktuell sieht das so aus:
Java:
public static void main(String[] args) {

    try {
        boolean tool1 = getArg(args, 0);
        boolean tool2 = getArg(args, 1);
        boolean tool3 = getArg(args, 2);
        boolean tool4 = getArg(args, 3);

        LOG.info("Tool1 = " + tool1);
        LOG.info("Tool2 = " + tool2);
        LOG.info("Tool3 = " + tool3);
        LOG.info("Tool4 = " + tool4);
        LOG.info(" ");

        if(tool1) {
            try { tool1.main(null); } catch (Exception e) { LOG.error("Fehler in tool1: ", e); }
        }
        if(tool2) {
            try { tool2.main(null); } catch (Exception e) { LOG.error("Fehler in tool2: ", e); }
        }
    } catch (Exception e) {
        LOG.error("Fehler im Prüfer", e);
    }
}

private static boolean getArg(String[] args, int i) {
    if(args == null) return true;
    if(args.length == 0) return true;
    if((args.length - 1) < i) return false;

    String arg = args[i];

    return ("1".equals(arg));
}
Ich suche aber nach einer Möglichkeit, dass man das irgendwie "lesbar" konfigurieren könnte. Mir fällt aber nichts ein.
 

KonradN

Super-Moderator
Mitarbeiter
Du kannst doch den Tools einfach Namen geben und dann eben diese als Parameter verwenden. Also dann sind die Aufrufe halt mit den Parametern "tool1 tool3" und dann ist klar: tool1 und tool3 sollen gestartet werden.

Wie das implementiert werden kann, hängt dann von den ganz genauen Anforderungen ab. Wenn die Reihenfolge fest steht, in der die Aufrufe erfolgen sollen, dann könnte es einfach ein Set sein, das gefüllt wird. Wenn etwas kein gültiger Wert ist (Werte können übe reine enum definiert sein), dann kannst Du auf den falschen Parameter reagieren. Und bei der Ausführung prüfst Du dann: Ist in dem Set das Tools.TOOL1 enthalten? Ja, dann ausführen.
Und ohne Parameter wird alles ausgeführt? Das kann dann halt die erweitere Prüfung sein: "Ist Tools.TOOL1 im set enthalten oder ist das set leer?" (Oder Du erzeugst dann ein Set mit allen Elementen - dann kannst Du da leichter etwas anpassen)
 

DaBe1812

Bekanntes Mitglied
Das klingt erstaunlich einfach mit den Enums.
Hatte Zwischenzeitlich schon über eine Config nachgedacht, in der ich Sets definiere für wöchentliche tägliche und spezielle Ausführungen und dann eben diese Listen ähnlich verwende.
Aber noch lebe ich und bin in der Firma, da kann ich mir mal einen Kopf machen.
 

Barista

Top Contributor
Das System ist von außen nicht wirklich wartbar, bzw. man kann nicht direkt sehen, was eine 1 an welcher Stelle macht.
Bei den meisten Kommandozeilen-Tools werden Argumente so übergeben, dass es eine Option gibt, deren Name ein Minuszeichen oder Schrägstrich oder anderes als Vorzeichen hat.

Auf die Option folgt dann der eigentliche Wert.

Dafür gibt es jede Menge Java-Libs.

Google Suche: java command line library
 

Robert Zenz

Top Contributor
Du koenntest auch beinhart die Klassennamen verwenden:

Code:
your-program.java firsttool secondtool

Java:
List<Class<?>> toolClasses = new ArrayList<>();

for (String arg : args) {
    toolClasses.add(Main.class.getClassLoader().loadClass("your.package.tools." + arg));
}

for (Class<?> toolClass : toolClasses) {
    System.out.println("Running <" + toolClass.getName() + ">...");
    toolClass.getMethod("main").invoke();
}

Ist etwas Pseudo-Code, aber das sollte dir eine grobe Idee geben. Der Nachteil ist man muss die Klassennamen kennen, aber die Parameter muss man so oder so wissen.

---

Fuer das Verwalten von Kommandozeilenargumenten ist picocli wirklich super, hat haufenweise Funktionalitaet.
 

KonradN

Super-Moderator
Mitarbeiter
Ich habe hier jetzt evtl. eine Meinung, mit der ich etwas alleine da stehe, aber ich finde, man bindet hier eine ganze Library ein für etwas, das eigentlich sehr einfach schnell selbst implementiert ist. Vor allem holt man sich eine Komplexität ins Haus, die man gar nicht braucht.

So habe ich (für deutlich komplexere Anforderungen) Mal zwei Klassen geschrieben, die Argumente parsen können. Die eine Klasse ist halt der ArgumentParser der das eigentliche Doing macht und die zweite Klasse ist der Parameter, der beschrieben wird. Der hat dann so Dinge wie:
  • der eigentliche Parameter (z.B. eben das "-x")
  • kurze Beschreibung ("-x <whatever> : Setzt den Parameter x")
  • lange Beschreibung ("-x macht was ganz tolles ... und ich beschreibe hier so viel Roman wie ich will ...")
  • Anzahl zusätzliche Werte (min / max)
  • Callback (Da wurden dann die zusätzlichen Werte mit übergeben)

Das liess sich dann auch sehr einfach nutzen und man hatte halt direkt auch die Usage über die kurze Beschreibung und die Möglichkeit eine lange Beschreibung anzufordern.

Die erste Version hatte das mit der Dokumentation nicht mit drin - aber war in sehr kurzer Zeit geschrieben. Aber selbst das ist ja hier schon overkill. Das kann ja schon einfach sein:
Java:
for (String arg : args) {
    switch(arg) {
        case "Test1" :
            doTest1();
            break;
            
        case "Test2" :
            doTest2();
            break;
            
        case "Test3" :
            doTest3();
            break;
            
        case "Test4" :
            doTest4();
            break;
            
        default:
            System.out.println("Argument " + arg + " unknown!");
    }
}
(So man damit leben kann, das die Reihenfolge und Anzahl der Aufrufe nicht festgelegt ist. Ein Aufruf mit Test3 Test1 Test1 würde halt Test3 zuerst aufrufen und dann Test1 zwei mal.)
 

Robert Zenz

Top Contributor
Ich habe hier jetzt evtl. eine Meinung, mit der ich etwas alleine da stehe, aber ich finde, man bindet hier eine ganze Library ein für etwas, das eigentlich sehr einfach schnell selbst implementiert ist. Vor allem holt man sich eine Komplexität ins Haus, die man gar nicht braucht.
Ja, das ist richtig, aber ich wollte es mal erwaehnt haben wenn mir die Bibliothek gut gefaellt. Mit picocli bekommt man auch viele Sachen direkt dazu, zum Beispiel --help Ausgaben, man pages, Shell Autovervollstaendigungen und noch so biszchen was. Ob man das alles braucht oder nicht, ist eine andere Frage. Das, und viele moegen Annotations-basierte Loesungen.

Ich finde das Projekt schon interessant, aber fuer 'kleinere Sachen' schreibe ich auch immer das Zerlegen der Argumente selbst.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E Java .exe Datei mit args starten Allgemeine Java-Themen 2
B Input/Output Konsolen input args Allgemeine Java-Themen 6
T Java applet args Allgemeine Java-Themen 5
X Übergabe ... args Allgemeine Java-Themen 5
H args abfrage vereinfachen Allgemeine Java-Themen 7
L Apache CLI: Args[] übergeben Allgemeine Java-Themen 3
N args Allgemeine Java-Themen 4
J Unicode: cmd parameter (main args); exec params; filenames Allgemeine Java-Themen 2
T Problme mit args Argumenten Allgemeine Java-Themen 17
W Vergleichstool für xml-Dateien Tortoise-svn Verknüpfung Allgemeine Java-Themen 2
Zrebna Tipps für Organisation von Code-Reviews nach einem Pull Request. Allgemeine Java-Themen 5
Zrebna Bitte um Empfehlungen für "zeitlose" Bücher bzgl. Backend mit Spring und Beans Allgemeine Java-Themen 25
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben