我在Java中創建了我的第一個應用程序(但已經用C#和Python編程),並且遇到了一個我根本無法理解的問題,因爲調試器消息對用戶非常不友好。 ;-)有史以來的第一個Java應用程序;不能在數據庫中查詢?
調試器輸出看起來像這樣:
調試:異常在線程 「AWT-EventQueue的-0」 在 Kwestionariusz.MainWindow.jButton1ActionPerformed(MainWindow.java顯示java.lang.NullPointerException: 176) 在Kwestionariusz.MainWindow.access $ 100(MainWindow.java:14)在 Kwestionariusz.MainWindow $ 2.actionPerformed(MainWindow.java:72)在 javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2018) 在 javax.swing.AbstractButton $ Handler.actionPerformed(AbstractButton.java:234 1) 在 javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402) 在 javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259) 在 javax.swing.plaf.basic.BasicButtonListener.mouseReleased (BasicButtonListener.java:252) at java.awt.Component.processMouseEvent(Component.java:6505)at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)at java.awt.Component.processEvent(Component .java:6270)at java.awt.Container.processEvent(Container.java:2229)at java.awt.Component.dispatchEventImpl(Component.java:4861)at java.awt.Container.dispatchEventImpl(Container.java :2287)在 java.awt.Component.dispatchEvent(Component.java:4687)在 java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832) 在 java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492) 在java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422) at java.awt.Container.dispatchEventImpl(Container.java:2273)at java.awt.Window.dispatchEventImpl(Window.java:2719)at java .awt.Component.dispatchEvent(Component.java:4687)在 java.awt.EventQueue.dispatchEventImpl(EventQueue.java:703)在 java.awt.EventQueue.access $ 000(EventQueue.java:102)在 的Java。 awt.EventQueue $ 3.run(EventQueue.java:662)at java.awt.EventQueue中的$ 3.run(EventQueue.java:660)在 java.security.AccessController.doPrivileged(本機方法)在 java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:76) 在 的java .security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:87) at java.awt.EventQueue $ 4.run(EventQueue.java:676)at java.awt.EventQueue $ 4.run(EventQueue.java:674)at java.security.AccessController.doPrivileged(Native Method)at java.security.ProtectionDomain $ 1.doIntersectionPrivilege(ProtectionDomain.java:76) at java.awt.EventQueue.dispatchEvent(EventQueue.java:673)at java.awt。 EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:244) 在 java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:163) 在 java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:151) 在 java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:147 ) at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:139) at java.awt.EventDispatchThread.run(EventDispatchThread。Java的:97) BUILD SUCCESSFUL(總時間:16秒),
這也可能是一些與此動作:
if (("".equals(login)) || ("".equals(password)) || ("".equals(accountType)))
{}
else
{
Users user;
user = (Users) db.createNamedQuery("Users.findByLoginAndType")
.setParameter("login", login)
.setParameter("company", accountBool)
.getSingleResult();
if (password.equals(user.getPassword()))
{
JFrame appWindow;
appWindow = new AppWindow();
this.setVisible(false);
appWindow.setVisible(true);
}
}
其中:
@NamedQuery(name = "Users.findByLoginAndType", query = "SELECT u FROM Users u WHERE u.login = :login AND u.company = :companyBool LIMIT 1")
你有沒有通過調試器瞭解NPE的來源? – Zavior
您所看到的內容稱爲*堆棧跟蹤*。它顯示異常是在176行的MainWindow類中調用'jButton1ActionPerformed'方法拋出的。調用該方法的方法在14行,在72處由'actionPerformed'調用,等等。這是一個非常有用的工具,但您需要將其與調試器結合使用 - 您是否使用IDE? – wchargin
*「有史以來的第一個Java應用程序;無法在數據庫中查詢?」*哇!我的'第一次'Java頁(每次安裝或更新開發環境時編寫)都是'HelloWorld',但'更新數據庫' - 你很勇敢。 –