If Debug in JAVA?

Status
Nicht offen für weitere Antworten.

SegFault

Bekanntes Mitglied
nicht direkt. Höchstens über eine Statische Klasse mit diversen Options kannst du solche Präprozessor Direktiven "Simulieren" Sinnvoll ists allemal sowas zu machen. Ich habe immer entweder eine rein Statische Klasse (Also nur Statische Funktionen) oder eine Singleton klasse mit solchen Optionen drinnen die ich dann abfragen kann

sowas wie.
Code:
if (Options.getDebug() ) System.out.println(....);

direkte Präprozessordirektiven gehen nicht sind aber auch nicht wirklich von nöten.
 

Landei

Top Contributor
Nicht wirklich.
Du könntest z.B. eine Systemvariable setzen und abfragen. Oder du benutzt ein Logging-Framework (log4j, java.util.logging), dort kannst du das Log-Level setzen. Selbiges läßt sich sicher auch auslesen, um davon abhängig Code zu starten, aber das halte ich für schlechten Stil / aufkommenden Wahnsinn. Dann gibt es noch assert, das man über Kommandozeilenparamter ein- und ausschalten kann.
 

Marco13

Top Contributor
Manchmal ist das aber schon nachteilhaft
Code:
for (int i=0; i<10000000; i++)
{
   // In der innersten Schleife, wird gaaaanz oft ausgeführt:
   log(level, "Das Objekt ist "+einKomplexesObjektDessenToStringMethodeZehnMinutenRechnet);
}
Selbst wenn das logLevel besagt, dass garnichts ausgegeben wird, wird trotzdem der String gebaut.... :?
Abhilfe sind da ggf. solche sachen wie
Code:
private static final boolean LOCAL_BEDUG = false;
...
   if (LOCAL_DEBUG) log(level, "Das Objekt ist "+einKomplexesObjektDessenToStringMethodeZehnMinutenRechnet);
allerdings werden damit die LogLevel auch ad absurdum geführt....
 

Murray

Top Contributor
Marco13 hat gesagt.:
Selbst wenn das logLevel besagt, dass garnichts ausgegeben wird, wird trotzdem der String gebaut.... :?
Abhilfe sind da ggf. solche sachen wie
Code:
private static final boolean LOCAL_BEDUG = false;
...
   if (LOCAL_DEBUG) log(level, "Das Objekt ist "+einKomplexesObjektDessenToStringMethodeZehnMinutenRechnet);
allerdings werden damit die LogLevel auch ad absurdum geführt....
Um die Log-Level zu berücksichtigen, kann man dann besser mit org.apache.log4j.Logger.isEnabledFor bzw. java.util.logging.Logger.isLoggable arbeiten:
Code:
   if (log.isEnabledFor( level)) log(level, "Das Objekt ist "+einKomplexesObjektDessenToStringMethodeZehnMinutenRechnet);

Die Variante mit der static final Konstante hat allerdings theoretisch den Vorteil, dass ein optimierender Compiler die gesamte Anweisung aus dem Code entfernen kann.
 

SegFault

Bekanntes Mitglied
Murray hat gesagt.:
Die Variante mit der static final Konstante hat allerdings theoretisch den Vorteil, dass ein optimierender Compiler die gesamte Anweisung aus dem Code entfernen kann.

Womit wir wieder bei einer art Präprozessor direktiven wie bei C++ wären ;)
 

Ebenius

Top Contributor
Murray hat gesagt.:
Die Variante mit der static final Konstante hat allerdings theoretisch den Vorteil, dass ein optimierender Compiler die gesamte Anweisung aus dem Code entfernen kann.

Im Regelfall sollte man darauf verzichten, und lieber die entsprechenden Methoden des Log-Frameworks (oder notfalls Systemvariablen) benutzen. In ein paar Ausnahmefällen ist die static-final-Konstante allerdings tatsächlich nützlich. Ich habe in einem Projekt ein Auto-Login ohne Passwortabfrage, welches nur bei Test-Kompilaten funktioniert. Dieser Teil des Codes sollte in der ausgelieferten Software nicht enthalten sein.

Mit dem Sun-Compiler und mit Jad hab ich getestet; die if-Anweisungen (inkl. Block, versteht sich) aller nachfolgenden Beispiele sind nach dem Kompilieren weg.

Code:
if (false) {
  throw new InternalError();
}

Code:
public static boolean DEBUG = false;
void foo() {
  if (DEBUG) {
    throw new InternalError();
  }
}

Code:
public interface Debug {
  static boolean DEBUG = false;
}

public class Test {
  void foo() {
    if (Debug.DEBUG) {
      throw new InternalError();
    }
  }
}

Grüße, Ebenius
 

Murray

Top Contributor
Ebenius hat gesagt.:
Im Regelfall sollte man darauf verzichten, und lieber die entsprechenden Methoden des Log-Frameworks (oder notfalls Systemvariablen) benutzen.
Da gebe ich Dir Recht; die "static final"-Konstante würde auch auch nur dort benutzen, wo der Code - wie in Deinem Fall - aus Sicherheitsgründen nicht in der ausgelieferten Version enthalten sein soll oder sich beim Profilen zweifelsfrei erwiesen hat, dass die Abfrage über das Log-Framework wirklich signifikante Performance-Nachteile bringt.

Allgemein wäre ich aber ohnehin sehr vorsichtig mit Konstrukten wie
Code:
if ( testModus()) {
  /* mache etwas */
}
oder gar
Code:
if ( testModus()) {
  /* mache etwas */
} else {
  /* mache etwas anderes */
}
denn damit verhält sich das Programm im Testbetrieb ja anders als in Produktion
 
G

Gast

Gast
ihr wisst hoffentlich was mit #if debug gemeint ist ^^

bsp:
#if debug
MessageBox.Show("asd");
#endif

dieser test wird nur in der Debug version ausgeführt und NICHT mitkompliert ....
 

Marco13

Top Contributor
Murray hat gesagt.:
Die Variante mit der static final Konstante hat allerdings theoretisch den Vorteil, dass ein optimierender Compiler die gesamte Anweisung aus dem Code entfernen kann.
Darauf wollte ich mit meinem LOCAL_DEBUG hinaus. Wobei ich nicht weiß, wie Log4J das isDebugEnabled intern umsetzt.
 

Ebenius

Top Contributor
Gast hat gesagt.:
ihr wisst hoffentlich was mit #if debug gemeint ist ^^

Ich gehe davon aus, dass sowohl mir als auch den Vorrednern Preprocessor Directives bekannt sind. Solche gibt's in Java nicht. Es steht Dir frei, einen der existierenden Präprozessoren für Java zu benutzen (google hilft), davon ist jedoch IMHO abzuraten. Oben stehende Vorschläge sind als Alternativen dazu gemeint.

Vor einigen Jahren hab ich mal ein Sun-Paper gelesen, in dem Begründungen zu diversen Sprach-Entscheidungen standen (u. a. C-style preprocessor directives, compile-time constants, labels/goto, etc.), ich finde's aber nicht wieder. Dieser Artikel geht ein bisschen in die Richtung: Java Tip 5: Java constants

Ebenius
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Run und Debug eines Java-Projektes Java Basics - Anfänger-Themen 41
K Exception nur im "Debug"-Modus und jedem 3.-5. mal Ausführen Java Basics - Anfänger-Themen 3
Q Eclipse Debug Mode Java Basics - Anfänger-Themen 2
O Debug-Funktion mit Slick - Kleines Problem Java Basics - Anfänger-Themen 5
J Probleme mit Debug Java Basics - Anfänger-Themen 3
D Debug Current Instruction Pointer Fehler Java Basics - Anfänger-Themen 8
J Tipp: Informativere Debug-Meldungen ausgeben Java Basics - Anfänger-Themen 4
P Debug- Modus Java Basics - Anfänger-Themen 3
G Eclipse debug JVM_Bind Java Basics - Anfänger-Themen 6
F [Hibernate] Debug INFO Einstellungen Java Basics - Anfänger-Themen 5
N Unterschiedliche Resultate bei RUN und DEBUG !? Java Basics - Anfänger-Themen 8
tomzen Java Unterstützung für exel dateien installieren. Java Basics - Anfänger-Themen 2
Rookar java.lang.NoClassDefFoundError: org/json/JSONException Java Basics - Anfänger-Themen 2
Rookar Mit Button andere java öffnen Java Basics - Anfänger-Themen 4
F Java Object to Hashmap ? Java Basics - Anfänger-Themen 6
I Backend in Java und Ansicht von Dateien in statische HTML Seiten? Java Basics - Anfänger-Themen 15
R Input/Output Verwendung des Euro-Zeichens in Java Java Basics - Anfänger-Themen 7
I Push Nachrichten von JAVA EE App an Mobile App Java Basics - Anfänger-Themen 3
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32

Ähnliche Java Themen

Neue Themen


Oben