- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web NullPointerException
下面是抛出异常的方法:
/**
*
*/
package com.servlet.pgsql;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
/**
*
*/
public class RecupData {
/**
* Connection connection
*/
static String SqlSinRef = "SELECT * FROM \"SINref\""; // view in pgsql - contain only 1 column
static Connection connection;
static Statement statement;
/**
* cette méthode sert pour toutes les connections de la classe RecupData
*/
public static Statement state() {
try{
connection = UniqueConnection.getInstance();
statement = connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
}
catch(Exception e) { e.printStackTrace(); }
return statement;
}
public static String htmlListeRefDossier() {
ResultSet resultat;
String listeHtml = "<form>\n" +
"\t<select>\n";
try {
resultat = state().executeQuery(SqlSinRef);
while(resultat.next()) {
listeHtml = listeHtml+"\t\t<option>"+resultat.getString(1)+"</option>\n"; }
}
catch (SQLException e) {
listeHtml = listeHtml+"sql exception sortie";
e.printStackTrace();
}
catch (NullPointerException e) {
listeHtml = listeHtml+"null pointer exception -sortie";
e.printStackTrace();
}
listeHtml = listeHtml+"\t</select>\n</form>";
return listeHtml;
}
/*
* valable just pour le dev
* method main only for test in console
*/
public static void main(String[] args) throws SQLException {
System.out.println(htmlListeRefDossier());
}
/*
* A SUPPRIMER
*/
} // fin class
这是唯一连接:
public class UniqueConnection {
private volatile static Connection connect;
public static Connection getInstance(){
if(connect == null){
synchronized(Connection.class){
try { connect = DriverManager.getConnection(url, user, passwd); }
catch(SQLException e) { e.printStackTrace(); }
}
}
return connect;
}
}
你能看一下吗?谢谢!
最佳答案
看这里:
public static Statement state() {
try{
connection = UniqueConnection.getInstance();
statement = connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
}
catch(Exception e) { e.printStackTrace(); }
return statement;
}
你的异常处理很差。如果 UniqueConnection.getInstance()
或 connection.createStatement()
抛出异常,则代码将立即跳转到 catch
block ,从而不影响 statement
变量,从而保持 null
。由于您只是将堆栈跟踪打印到标准输出并继续代码流,而不是抛出完全值得的异常,因此代码继续进入 return statements
行。由于 statement
仍为 null
,因此每当您尝试对返回值调用方法时,您都会收到 NullPointerException
。
resultat = state().executeQuery(SqlSinRef); // state() returns null, so NPE!
您需要阅读 catch
子句中打印的堆栈跟踪来查找问题的真正原因,而不是由 NPE 引起的原因。或者更好的是,抛出一个真正的异常,以便代码立即停止,而不是继续流程并使用可能为 null 的变量。
修复所有 catch
子句,这些子句只是吞掉异常并打印跟踪以引发真正的异常:
catch(SomeException e) { throw e; }
或者,更好的是,只需删除它们并在方法声明中使用throws
子句。仅当您能够以合理方式处理异常时(即采用替代路径、向最终用户显示错误屏幕并中止代码等;仅打印跟踪并继续使用null
变量绝对不是正确的替代路径),或者当您希望使用finally
block 来关闭和释放昂贵的资源时,您才应该使用try
block 。
我敢打赌,它实际上是SQLException:没有合适的驱动程序
,因为驱动程序加载失败并出现ClassNotFoundException org.postgresql.Driver
,并且您以相同的方式抑制了此异常。
与问题无关:您的代码存在更严重的问题。
您已将连接、语句和结果集等昂贵的数据库资源声明为类的静态
变量。这不是线程安全的!它在使用它们一次然后立即关闭的应用程序中可以正常工作。但在运行期间多次使用它们的应用程序(例如 Web 应用程序)中,它会严重失败。
您不想在网络应用程序的整个生命周期中使用“唯一连接”。一般数据库只要打开时间过长就会自动关闭。您需要在尽可能短的范围内获取并关闭连接、语句和结果集。如果您想提高连接性能,则应该使用连接池。
您的数据访问层与表示层极其紧密地耦合。您正在数据库访问类中而不是在 JSP 文件中构建一些 HTML 片段。
相应地修复它。您可以在以下问题的答案中找到一些启动示例:
关于java - jsp 中出现 NullPointerException,但控制台中没有出现 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6787972/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!