java util logging_java.util.logging.Logger使用详解

import java.io.IOException;

import java.io.PrintWriter;

import

java.io.StringWriter;

import java.util.Date;

import

java.util.logging.FileHandler;

import

java.util.logging.LogRecord;

import

java.util.logging.SimpleFormatter;

public class Logger {

private static FileHandler fh;

private static java.util.logging.Logger

logger;

public static class LogRecordFormatter extends SimpleFormatter {

public synchronized String format(LogRecord

record) {

Date dat = new Date();

dat.setTime(record.getMillis());

//  String source;

//  if (record.getSourceClassName() != null) {

//  source =

record.getSourceClassName();

//  if

(record.getSourceMethodName() != null) {

//  source += " " +

record.getSourceMethodName();

//  }

//  } else {

//  source =

record.getLoggerName();

//  }

String message = formatMessage(record);

String throwable = "";

if

(record.getThrown() != null)

{

StringWriter sw = new

StringWriter();

PrintWriter pw = new

PrintWriter(sw);

pw.println();

record.getThrown().printStackTrace(pw);

pw.close();

throwable

= sw.toString();

}

return String.format("%1$s: [%2$tb %2$td, %2$tY

%2$tH:%2$tM:%2$tS %2$tL %2$tz]: %3$s%4$s%n",

record.getLevel().getName(),

dat,

message,

throwable);

}

}

static {

try {

logger = java.util.logging.Logger.getLogger("TimedReminder");

fh = new

FileHandler("%h/TimedReminder%g.log");

fh.setFormatter(new LogRecordFormatter());

logger.addHandler(fh);

} catch (SecurityException e)

{

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

public static void info(final String msg) {

logger.log(java.util.logging.Level.INFO,

msg);

}

public static void warn(final String msg) {

logger.log(java.util.logging.Level.WARNING,

msg);

}

public static void infoe(final String msg, final Throwable ex) {

logger.log(java.util.logging.Level.INFO,

msg, ex);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值