【问题标题】:Access logger in different class访问不同类的记录器
【发布时间】:2013-06-18 06:11:10
【问题描述】:

我在我的主类中创建了一个记录器:

public static Logger logger = Logger.getLogger( MainClass.class.getName());

我将它声明为 public static。

这是 log4j.properties:

根记录器选项

log4j.rootLogger=INFO, file

将日志消息直接写入日志文件

log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=D:\\loging.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

现在我想在不同的类中访问这个记录器对象。 当我尝试直接提供记录器时,尽管我将其设为公开静态,但它给出了错误。

下面是我尝试访问记录器对象的类:

public class Db_Connector 
{
     MainClass.logger <------error
     //create ResultSet Class Object
     public ResultSet GetDataFromDB(){

        ResultSet resultset = null;
         try {  

                DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());   
                System.out.println("Connecting to the database...");   
                Connection connection = DriverManager.getConnection(
                        "jdbc:oracle:thin:@host:1521:Db", "User","pass01");
                Statement statement = connection.createStatement();   
                resultset = statement.executeQuery("select * from employee"); 

            } 
         catch (Exception e) {   
                System.out.println("The exception raised is:" + e);   
                            } 

         return resultset;
        }   
}

【问题讨论】:

  • 您遇到了什么错误,您是如何尝试访问记录器的?
  • 在另一个类中我正在尝试 MainClass.logger
  • 调用 MainClass.logger 时有什么异常 - 否则几乎无法提供帮助。
  • 请问,为什么要在类之间共享记录器实例?通常,您为每个类创建一个实例,因此通常不需要共享它。在这里讨论例如here

标签: java logging


【解决方案1】:

确保封装 Logger 的类也是公开的

【讨论】:

  • 请您提供您尝试访问记录器的代码部分
  • 您不能在将其标记为错误的位置调用MainClass.logger,您应该能够在方法MainClass.Logger.something()... 内正常访问它,即:在GetDataFromDB()
【解决方案2】:

您应该在 DB_Connector 类中创建 public static 变量并将 MainClass.logger 分配给它。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-08-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-08-17
    • 1970-01-01
    相关资源
    最近更新 更多