java new一个实例对象,为什么不等于null

我在写注册会员逻辑时。 当在注册页面填写用户名liuyifei。 发送请求后,去数据库中查询t_user表。
如果存在在用户名则返回注册页面;如果不存在,则添加此次注册信息。

为什么,数据库中不存在该用户名,返回的user实例不等于null呢。

public User findByUsername(String username) throws Exception
{
Connection conn = null;
User user = new User();
try
{
conn = DBUtil.getConnection();
String sql = "select * from t_user
where username=?";
PreparedStatement prep =
conn.prepareStatement(sql);
prep.setString(1, username);
ResultSet
rs =
prep.executeQuery();
while(rs.next()){
user.setUsername(rs.getString("username"));
user.setName(rs.getString("name"));
user.setPwd(rs.getString("pwd"));
user.setGendar(rs.getString("gendar"));
}
}
catch (Exception e)
{
e.printStackTrace();
}finally{
DBUtil.close(conn);
}
System.out.print("根据注册的用户名字段,到数据库t_user表中匹配。当该用户名不存在时,检验返回的user是否等于null:
");
System.out.println(user==null);
return user;
}

因为你事先声明了:User user = new User();
后续无论数据库是否查到数据,返回的都是这个不为null的user啊。
如果要达到期望的结果,可以改写成如下写法即可:

User user = null;
....
rs = prep.executeQuery();
while(rs.next()){
user = new User();
user.setXXX
..
}
return user;
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-03-18
User user = new User();
你是在这儿实例化的,并没有初始化为 null
如果查找不到记录就返回 null 的话,你可以这样
public void findByUsername(String username) throws Exception {
Connection conn = null;
User user = null; // 初始化 user 为null
try {
conn = DBUtil.getConnection();
String sql = "select * from t_user where username=?";
PreparedStatement prep = conn.prepareStatement(sql);
prep.setString(1, username);
ResultSet rs = prep.executeQuery();
if (rs.next()) { // 如果返回一条记录,此处不要使用 while
user = new User(); // 如果有返回记录,则初始化 User,并赋值
user.setUsername(rs.getString("username"));
user.setName(rs.getString("name"));
user.setPwd(rs.getString("pwd"));
user.setGendar(rs.getString("gendar"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
}
System.out.print("根据注册的用户名字段,到数据库t_user表中匹配。当该用户名不存在时,检验返回的user是否等于null: ");
System.out.println(user == null);
return user;
}
第2个回答  2013-03-22
你一开始就User user = new User();
一般我写的时候是不直接new出来的,以免浪费内存,因为你new出对象后,它会存在栈中,等到你方法执行结束后,才会等垃圾回收。
第3个回答  2018-01-31
因为你事先声明了:User user = new User();
后续无论数据库是否查到数据,返回的都是这个不为null的user啊。
如果要达到期望的结果,可以改写成如下写法即可:

User user = null;
....
rs = prep.executeQuery();
while(rs.next()){
user = new User();
user.setXXX
..
}
return user;
第4个回答  2013-03-21
你先用了User user=new User();这句话会初始化一个user,不论返回的结果是什么,他返回的都是你初始化的那个user。不想这样的话,就把一个user作为参数传进来,而不是你new一个
相似回答