为什么我在这里有NullPointerException?

时间:2009-12-12 09:21:05

标签: java mysql database

我创建了一个名为Manager的类,我有一个名为BirthList的Frame,这个框架有一个表。我使用MySQL,我在MySQL中的“诞生地”中输入了一些数据。我想要将MySQL表中的数据添加到我的框架中的表中。 提示:birthList是Birth对象的列表。 但我会发现这个例外为什么? 请帮帮我:(

经理班:

  public Manager class{
  Logger logger = Logger.getLogger(this.getClass().getName());
  private static Connection conn = DBManager.getConnection();
  private static Admin admin;

  public static void addToBirthListFromMySQL() throws SQLException {



    try{
      Statement  stmt = conn.createStatement();



     ResultSet rs= stmt.executeQuery("SELECT * FROM birthtable");

       Birth list1;

        while (rs.next()) {
            String s1 = rs.getString(2);
            if (rs.wasNull()) {
                s1 = null;
            }
            String s2 = rs.getString(3);
            if (rs.wasNull()) {
                s2 = null;
            }
            String s3 = rs.getString(4);
            if (rs.wasNull()) {
                s3 = null;
            }
            String s4 = rs.getString(5);
            if (rs.wasNull()) {
                s4 = null;
            }
            String s5 = rs.getString(6);
            if (rs.wasNull()) {
                s5 = null;
            }
            String s6 = rs.getString(7);
            if (rs.wasNull()) {
                s6 = null;
            }


          list1 = new Birth(s1, s2, s3, s4, s5, s6);
          admin.birthList.add(list1);


        }




    }
    catch(SQLException e){





    }

}

我的框架:

public class BirthList extends javax.swing.JFrame {

    private Admin admin;

    /** Creates new form BirthList */
    public BirthList(Admin admin) {
        initComponents();
        this.admin = admin;
        try {
            Manager.addToBirthListFromMySQL();
        } catch (SQLException ex) {
            Logger.getLogger(BirthList.class.getName()).log(Level.SEVERE, null, ex);
        }
        fillTable();
    }


public void fillTable() {

        String[] columNames = {"name", "family", "father's name", "mother's name", "date of birth", "place of birth"};
        List<Birth> birth = admin.getBirthList();
        Object[][] data = new Object[birth.size()][columNames.length];
        for (int i = 0; i < data.length; i++) {
            Birth birth1 = birth.get(i);
            data[i][0] = birth1.getName();
            data[i][1] = birth1.getFamily();
            data[i][2] = birth1.getFatherName();
            data[i][3] = birth1.getMotherName();
            data[i][4] = birth1.getDateOfBirth();
            data[i][5] = birth1.getPlaceOfBirth();


        }
        DefaultTableModel model = new DefaultTableModel(data, columNames);
        jTable1.setModel(model);
    }

    public boolean isCellEditable(int row, int col) {
        return true;
    }
}

堆栈跟踪: 线程“AWT-EventQueue-0”中的异常java.lang.NullPointerException         at database.Manager.addToBirthListFromMySQL(Manager.java:272)         在AdminGUI.BirthList。(BirthList.java:35)         在AdminGUI.BirthFrame.newButton1ActionPerformed(BirthFrame.java:127)         在AdminGUI.BirthFrame.access $ 000(BirthFrame.java:21)         在AdminGUI.BirthFrame $ 1.actionPerformed(BirthFrame.java:58)         在javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)         在javax.swing.AbstractButton $ Handler.actionPerformed(AbstractButton.java:2318)         在javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)         在javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)         在javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)         at java.awt.Component.processMouseEvent(Component.java:6038)         在javax.swing.JComponent.processMouseEvent(JComponent.java:3265)         at java.awt.Component.processEvent(Component.java:5803)         at java.awt.Container.processEvent(Container.java:2058)         at java.awt.Component.dispatchEventImpl(Component.java:4410)         at java.awt.Container.dispatchEventImpl(Container.java:2116)         at java.awt.Component.dispatchEvent(Component.java:4240)         at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322)         at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986)         at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916)         at java.awt.Container.dispatchEventImpl(Container.java:2102)         at java.awt.Window.dispatchEventImpl(Window.java:2429)         at java.awt.Component.dispatchEvent(Component.java:4240)         at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)         at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:273)         at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:183)         at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:173)         at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168)         at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160)         在java.awt.EventDispatchThread.run(EventDispatchThread.java:121)

第272行是:admin.birthList.add(list1);

**我也调试我的项目,结果是:

调试: 听javadebug 用户程序正在运行 调试器在无法编译的源代码上停止。

*我还用system.out.println(admin)打印我的对象admin,结果是:

classes.Admin@20be79 *

4 个答案:

答案 0 :(得分:3)

我认为最好解释NPE是如何以及为什么会被引起以及如何避免它们,以便OP可以应用新获得的知识来捕捉他/她自己的琐碎问题,而不是在黑暗中寻找根本原因。

看,对象引用(变量)可以包含一个完整的Object或只是 nothing ,它是null

SomeObject someObject1 = new SomeObject(); // References something.
SomeObject someObject2 = null; // References nothing.

现在,如果您尝试访问 nothing null),那么您无疑会获得NullPointerException,因为null不会有任何变量或方法。

someObject1.doSomething(); // Works fine.
someObject2.doSomething(); // Throws NullPointerException.

解决此问题非常简单。它基本上可以通过两种方式完成:通过实例化或者忽略它。

if (someObject2 == null) {
    someObject2 = new SomeObject();
}
someObject2.doSomething(); // No NPE anymore!

if (someObject2 != null) {
    someObject2.doSomething(); // No NPE anymore!
}

对于NPE,堆栈跟踪的第一个行号指向引起它的确切行。你直截了当地说“第272行是admin.birthList.add(list1);”。此行包含两个位置,其中访问/调用了对象引用(使用点.运算符)。第一个是admin.birthList,第二个是birthList.add(list1)。由您来确定是否有一个或两个都导致了NPE。如果是第一次调用,则admin只是null。如果是第二次调用,则birthList只是null。您可以通过使用适当的对象实例化它来修复它。

编辑:如果你很难确定根本原因(从评论中得出结论),那么你需要学习调试。在访问/调用它们之前,运行调试器或在每个变量的System.out.println()的帮助下执行“穷人的调试”。首先看一下造成NPE的地方。如果这是例如

admin.birthList.add(list1);

然后您需要按照以下方式更改它以确定根本原因:

System.out.println("admin: " + admin);
List<Birth> birthList = admin.birthList;
System.out.println("birthList: " + birthList);
birthList.add(list1);

检查是否有任何人打印null。或者你也可以这样做:

if (admin == null) throw new NullPointerException("admin is null!");
List<Birth> birthList = admin.birthList;
if (birthList == null) throw new NullPointerException("birthList is null!");
birthList.add(list1);

您还可以通过单独的行分隔各个调用,以便您有足够的行号来知道哪个引用为空。

List<Birth> birthList = admin.birthList; // If NPE line points here, then admin is null.
birthList.add(list1); // If NPE line points here, then birthList is null.

答案 1 :(得分:2)

乍一看,我会说你的Admin实例为空,导致addToBirthListFromMySQL()方法中的NPE

public BirthList(Admin admin) {
        initComponents(); // where do you set this.admin to the parameter 'admin' ?

您还需要初始化静态对象admin的静态变量Manager

public BirthList(Admin admin) {
        this.admin = admin
        Manager.admin = admin
        initComponents();

(注意:您可能不希望使用与内部变量相同的名称调用参数)


  

我还调试了我的项目,结果是

debug: Have no FileObject for C:\Program Files\Java\jdk1.6.0_02\jre\lib\sunrsasign.jar

Have no FileObject for C:\Program Files\Java\jdk1.6.0_02\jre\classes**

确保您没有使用1.6编译器和1.5运行时来执行/调试程序。

请参阅this thread

  

以下列出了未来用户的可能性:

     
      
  1. 致力于存储库。 (可能不是)
  2.   
  3. 重新设置所有负责任的环境变量...
      一个。 set path="D:\...\JDK1.5\bin"
      湾set classpath="D:\...\JDK1.5\bin"
      C。 set java_home="D:\...\JDK1.5"
  4.   
  5. 在我的项目中重新设置所有依赖项。 (Project Properties->Libraries)。
  6.   

答案 2 :(得分:0)

很难分辨,因为堆栈跟踪中的行号似乎与您的代码不匹配,但是您是否设置了“private static Admin admin”; Manager中的变量为非空值?

答案 3 :(得分:0)

如果Manager.java的第272行是:

admin.birthList.add(list1);

如果admin不是null,这是我对您的更新的理解,那么结论似乎非常明显:birthlistnull,当您致电时代码会中断它上面有add()方法。

我的猜测是你的Admin课程看起来像这样:

public class Admin {
    public List<Birth> birthList; //the visibility seems to be public
    ...
}

并且您永远不会初始化birthList类属性。因此要么在内联中,在构造函数中,在init()方法中初始化它,等等,而是在某处进行。例如,内联:

public class Admin {
    public List<Birth> birthList = new ArrayList<Birth>(); 
    ...
}

实际上,我不确定如何实例化和设置Admin类的Manager静态实例,但这是另一个故事。