在工作中有遇到一个问题,需要从既有获取数据库中的LIST数据,做一下对其中部分数据做处理存入另外一个LIST集合之中,但是,有些现象还是比较出乎我的意料的,模拟了一下相关场景,具体的代码如下:
package com.interview.demo;
import java.util.ArrayList;
import java.util.List;
class Student {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
public class ListTest {
public static void main(String[] args) {
List<Student> stuList = new ArrayList<>();
Student stu1 = new Student();
stu1.setAge(18);
stu1.setName("张三");
Student stu2 = new Student();
stu2.setAge(19);
stu2.setName("李四");
stuList.add(stu1);
stuList.add(stu2);
List<Student> copyStuList = new ArrayList<>();
// 如果是将tempStudent定义在外层,
// 则会导致最后copyStuList存储的值均为"李四"的数据
Student tempStudent = new Student();
for (Student stu : stuList) {
// 这样一来,将tempStudent定义在循环内,
// 可以解决数据均为同一个"李四"数据的问题,但需要更多资源
// Student tempStudent = new Student();
tempStudent.setName(stu.getName());
tempStudent.setAge(stu.getAge());
copyStuList.add(tempStudent);
}
// 输出原来的学生LIST数据
System.out.println(stuList);
// 输出COPY的学生LIST数据
System.out.println(copyStuList);
}
}
不知道这样类似的问题,有没有什么更好的解决方案?