繁体   English   中英

连接工厂中的java.lang.ExceptionInInitializerError

[英]java.lang.ExceptionInInitializerError in Connection Factory

您好,下面是我的代码,它将用作Connection Factory类。 但是我正在获取java.lang.ExceptionInInitializerError。 请咨询如何解决? 我认为这是由于静态块造成的陷阱,但不知道这到底是什么。

package j2ee.dao;  
import java.sql.Connection;  
import java.sql.DriverManager;  
import java.util.Properties;  

public class ConnFactory  
{  
    public static  Properties prop;  
    static   
    {  
        prop=new Properties();  
        try {  
            prop.load(ConnFactory.class.getClassLoader().getResourceAsStream("DBConfig.properties"));  

        } catch (Exception e) {  
            e.printStackTrace();  
        }     
    }  

    private static ConnFactory instance = new ConnFactory();  
    public static final String URL = prop.getProperty("DEVURL");  
    public static final String USER = prop.getProperty("DEVUSER");  
    public static final String PASSWORD = prop.getProperty("DEVPASSWORD");  
    public static final String DRIVER_CLASS = prop.getProperty("DEVDRIVER_CLASS");  

    private ConnFactory() {  
        try {  
            Class.forName(DRIVER_CLASS);  
        } catch (ClassNotFoundException e) {  
            e.printStackTrace();  
        }  
    }  

    private Connection createConnection() {  
        Connection connection = null;  
        try {  
            connection = DriverManager.getConnection(URL, USER, PASSWORD);  
        } catch (Exception e) {  
            System.out.println("ERROR: Unable to Connect to Database.");  
        }  
        return connection;  
    }    

    public static Connection getConnection() {  
        return instance.createConnection();  
    }  
    public static void main(String a[])  
    {  
        Connection test=ConnFactory.getConnection();  
        System.out.println("Done");  

    }  

} 

错误是:

Caused by: java.lang.NullPointerException
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:188)
    at j2ee.dao.ConnFactory.<init>(ConnFactory.java:28)
    at j2ee.dao.ConnFactory.<clinit>(ConnFactory.java:20)
private static ConnFactory instance = new ConnFactory(); // DRIVER_CLASS is null at this point
...
public static final String DRIVER_CLASS = ...;

您创建的实例ConnFactory之前DRIVER_CLASS被初始化,因此DRIVER_CLASSnull的的构造ConnFactory

您需要颠倒这些静态字段声明的顺序:

public static final String DRIVER_CLASS = ...;
...
private static ConnFactory instance = new ConnFactory()

实际上,我认为最好完全消除这些静态字段。 只需使其变为非静态,然后在构造函数中对其进行初始化即可。

您还可以将Properties的实例传递给构造器,以使连接创建与连接属性的存储脱钩。 如果这样做,您将能够在不同情况下使用不同的属性集(例如,用于测试和生产环境)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM