我有一个函数,如果参数存在于数据库中,则返回一个 ID 号。如果不是,则返回 null。这是在乞求空指针异常吗?不允许使用负 ID 号,但我认为让不存在的参数返回 null 而不是像 -1 这样的错误代码会更清楚。你怎么认为?
private Integer tidOfTerm(String name) throws SQLException {
String sql = "SELECT tid FROM term_data WHERE name = ?";
PreparedStatement prep = conn.prepareStatement(sql);
prep.setString(1, name);
ResultSet result = prep.getResultSet();
if (result.next()) {
return result.getInt("tid");
}
return null; // TODO: is this begging for a null pointer exception?
}
这是完全合法的。如果您想避免 NPE,请抛出自定义异常。但不要返回负数。如果调用者不检查返回值,你总会遇到问题。但做false计算(因为结果例如乘以-1)肯定比未捕获的异常更难调试。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)