1、集合元素是String类型(final修饰)
代码如下(示例):
public class TestStreamString {
static final String[] NAME = {"zhangSan", "maLiu", "wangWu"};
public static void main(String[] args) {
ArrayList<String> strings = new ArrayList<>(Arrays.asList(NAME));
List<String> collect = strings.stream().collect(Collectors.toList());
strings.add("guQi");
strings.set(0, "张三");
System.out.println("同一个集合?:"+(strings==collect));
System.out.println("原集合:"+strings);
System.out.println("新集合:"+collect);
System.out.println("第一个元素:"+(collect.get(0).equals(strings.get(0))));
System.out.println("第二个元素:"+(collect.get(1).equals(strings.get(1))));
}
}
运行结果!
可以看到确实不是同一个集合,原集合操作不会影响到新集合,但是他们的元素指向了同一内存地址。(String不可变字符串)
1、集合元素是实体类
代码如下(示例):
public class TestStreamStudent {
public static void main(String[] args) {
Student zhangSan = new Student("张三");
Student maLiu = new Student("马六");
Student wangWu = new Student("王五");
ArrayList<Student> students = new ArrayList<>(Arrays.asList(zhangSan, maLiu, wangWu));
List<Student> collect = students.stream().collect(Collectors.toList());
students.add(new Student("顾七"));
students.get(0).setName("zhangSan");
System.out.println("同一个集合?:"+(students==collect));
System.out.println("原集合:"+students);
System.out.println("新集合:"+collect);
System.out.println("第一个元素:"+(collect.get(0).equals(students.get(0))));
System.out.println("第二个元素:"+(collect.get(1).equals(students.get(1))));
}
@Data
@AllArgsConstructor
@Getter
@Setter
static class Student {
private String name;
}
}
运行结果!
返回的是一个新的集合确认了,集合上做添加修改操作不会影响到新的集合,元素指向的还都是同一个元素,所以修改实体类的属性就会影响到新的集合。
总结
其实就是涉及到一个深拷贝浅拷贝的问题,因为String类型是不可变的,所以不管深拷贝还是浅拷贝其实都没有关系。浅拷贝会复制对象的引用,而不是对象本身。这意味着原始对象和拷贝对象都会指向相同的内存地址,因此对其中一个对象的修改会影响到另一个对象。