我正在写一个图书馆。该库可供使用 log4j 记录器和 java.util.logging 记录器的应用程序使用。
因此,我编写了一个快速包装类,它封装了两个记录器。我允许应用程序设置一个或两个记录器。在我的库中,我使用封装的类打印到任一记录器。
我的问题是,由于许多线程可以同时使用包装类的同一实例来使用类的方法(例如:下面的 fatal() )记录消息,应该采取哪些步骤来使这些方法线程安全?
public class MultiLogger {
private static org.apache.log4j.Logger _log4jLogger = null;
private static java.util.logging.Logger _javaUtilLogger = null;
private MultiLogger () {
}
// log4j FATAL, log util SEVERE
public void fatal (Object message) {
if (_log4jLogger != null) {
_log4jLogger.log("", Level.FATAL, message, null);
}
if (_javaUtilLogger != null) {
_javaUtilLogger.severe((String) message);
}
}
...
}
任何其他评论也很感激。