原因就是:代码中实例化mod对象时,内存中就把这一个mod对象存储在了堆上,并且在栈上分配了一个指向堆的地址;我们在一次次循环,改变mod的各个属性值的时候,其实是在改变堆,但是list.add(mod)的时候,添加mod对象,实际上是添加mod存在栈上指向堆的地址,地址自始至终没有发生改变,而堆上的数据,一直在被覆盖,直到最后一条数据;所以,到最后,我们分现,数据总数对,但是数据却是一样的,并且还都是最后一条的原因,就是这个!
解决办法
我们只需要把实例化对象的操作,写在循环内部就好
出错前的代码
Connection connection=connection();
Person person =new Person();
PreparedStatement ps=null;
ArrayList<Person> list =new ArrayList<>();
ps=connection.prepareStatement("select * from person where age >=?");
ps.setInt(1,age);
ResultSet resultSet = ps.executeQuery();
while (resultSet.next()){
person.setName(resultSet.getString("name"));
person.setAge(resultSet.getInt("age"));
list.add(person);
}
修改后的代码
PreparedStatement ps=null;
ArrayList<Person> list =new ArrayList<>();
ps=connection.prepareStatement("select * from person where age >=?");
ps.setInt(1,age);
ResultSet resultSet = ps.executeQuery();
while (resultSet.next()){
Person person =new Person();
person.setName(resultSet.getString("name"));
person.setAge(resultSet.getInt("age"));
list.add(person);
}