gpt4 book ai didi

java - 为什么我这里有 NullPointerException?

转载 作者:搜寻专家 更新时间:2023-10-30 21:48:35 37 4
gpt4 key购买 nike

我创建了一个名为 Manager 的类,我有一个名为 BirthList 的框架,这个框架有一个表。我使用 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 在 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) 在 java.awt.Component.processMouseEvent(Component.java:6038) 在 javax.swing.JComponent.processMouseEvent(JComponent.java:3265) 在 java.awt.Component.processEvent(Component.java:5803) 在 java.awt.Container.processEvent(Container.java:2058) 在 java.awt.Component.dispatchEventImpl(Component.java:4410) 在 java.awt.Container.dispatchEventImpl(Container.java:2116) 在 java.awt.Component.dispatchEvent(Component.java:4240) 在 java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322) 在 java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986) 在 java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916) 在 java.awt.Container.dispatchEventImpl(Container.java:2102) 在 java.awt.Window.dispatchEventImpl(Window.java:2429) 在 java.awt.Component.dispatchEvent(Component.java:4240) 在 java.awt.EventQueue.dispatchEvent(EventQueue.java:599) 在 java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:273) 在 java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:183) 在 java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:173) 在 java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168) 在 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*

最佳答案

与其在黑暗中寻找根本原因,我认为最好解释 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。您可以通过使用完全有值(value)的对象对其进行实例化来修复它。

编辑:如果您很难确定根本原因(从评论中得知),那么您需要学习调试。在访问/调用每个变量之前,在每个变量的 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.

关于java - 为什么我这里有 NullPointerException?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1892851/

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com