Les JavaDocs pour l'java.util.logging.Level
état:
Les niveaux par ordre décroissant sont:
SEVERE
(valeur la plus élevée)WARNING
INFO
CONFIG
FINE
FINER
FINEST
(valeur la plus basse)
La source
import java.util.logging.*;
class LoggingLevelsBlunder {
public static void main(String[] args) {
Logger logger = Logger.getAnonymousLogger();
logger.setLevel(Level.FINER);
System.out.println("Logging level is: " + logger.getLevel());
for (int ii=0; ii<3; ii++) {
logger.log(Level.FINE, ii + " " + (ii*ii));
logger.log(Level.INFO, ii + " " + (ii*ii));
}
}
}
Production
Logging level is: FINER
Jun 11, 2011 9:39:23 PM LoggingLevelsBlunder main
INFO: 0 0
Jun 11, 2011 9:39:24 PM LoggingLevelsBlunder main
INFO: 1 1
Jun 11, 2011 9:39:24 PM LoggingLevelsBlunder main
INFO: 2 4
Press any key to continue . . .
Énoncé du problème
Mon exemple définit le Level
sur FINER
, donc je m'attendais à voir 2 messages pour chaque boucle. Au lieu de cela, je vois un seul message pour chaque boucle (les Level.FINE
messages sont manquants).
Question
Que faut-il changer pour voir la sortie FINE
(, FINER
ou FINEST
)?
Mettre à jour (solution)
Grâce à la réponse de Vineet Reynolds , cette version fonctionne selon mes attentes. Il affiche 3 x INFO
messages et 3 x FINE
messages.
import java.util.logging.*;
class LoggingLevelsBlunder {
public static void main(String[] args) {
Logger logger = Logger.getAnonymousLogger();
// LOG this level to the log
logger.setLevel(Level.FINER);
ConsoleHandler handler = new ConsoleHandler();
// PUBLISH this level
handler.setLevel(Level.FINER);
logger.addHandler(handler);
System.out.println("Logging level is: " + logger.getLevel());
for (int ii=0; ii<3; ii++) {
logger.log(Level.FINE, ii + " " + (ii*ii));
logger.log(Level.INFO, ii + " " + (ii*ii));
}
}
}