ResultSet rs = this.getData(sql);
Student student = new Student();
while(rs.next()){
student.setsId(rs.getInt("sid"));
student.setsName(rs.getString(2));
student.setSex(rs.getString("sex"));
student.setsBorndate(rs.getDate("sborndate"));
student.setsAge(rs.getInt("sage"));
student.setsEmail(rs.getString("semail"));
student.setPwd(rs.getString("pwd"));
student.setCityId(rs.getInt("cityid"));
list.add(student);
}
return list;
问题来源:
本来想通过循环为student对象赋值,将其信息存储到list集合中。
自认为在循环外只创建一个对象会节省内存会,打印时却发现list存储的都是student的最后一次赋的值。
分析:
在循环外创建一份对象,申请一份内存空间,然而在for循环内赋值,student只会保留最后一次的值。又因list保存的只是student的引用,也就是list中的student引用 指向不断被·更改,指向了 同一块内存区间,造成了list里面的值相同。
改进:
ResultSet rs = this.getData(sql);
while(rs.next()){
Student student = new Student();
//不能放在循环外,因为list只保存student的引用
//而student循环赋值,导致指向了同一块区间
student.setsId(rs.getInt("sid"));
student.setsName(rs.getString(2));
student.setSex(rs.getString("sex"));
student.setsBorndate(rs.getDate("sborndate"));
student.setsAge(rs.getInt("sage"));
student.setsEmail(rs.getString("semail"));
student.setPwd(rs.getString("pwd"));
student.setCityId(rs.getInt("cityid"));
list.add(student);
}
return list;