java中List.add方法进行添加元素,发生覆盖问题

问题原因:
对于List.Add(),如果添加的是基本类型(值),则添加的为值;若添加为引用类型(对象),则添加的为引用的地址。
所以,循环添加时,添加的都是同一个对象引用,对象的成员值改变,List中所有对象的值就改变了。

解决方法:
每次在改变值之前重新new一下对象,从而改变存储的引用地址,这样就不会发生元素覆盖。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaList.sort()方法是用来对List集合的元素进行排序的。它可以按照自然顺序或者指定的比较器进行排序。 使用方法如下: 1. 自然排序 List集合的元素必须实现Comparable接口,重写compareTo()方法,才能使用自然排序。 例如: List<Integer> list = new ArrayList<>(); list.add(3); list.add(1); list.add(2); list.sort(null); //使用自然排序 System.out.println(list); //[1, 2, 3] 2. 指定比较器排序 如果List集合的元素没有实现Comparable接口,或者需要按照不同的排序规则进行排序,可以使用Comparator接口来指定比较器。 例如: List<Student> list = new ArrayList<>(); list.add(new Student("Tom", 18)); list.add(new Student("Jerry", 20)); list.add(new Student("Alice", 19)); list.sort(new Comparator<Student>() { @Override public int compare(Student o1, Student o2) { return o1.getAge() - o2.getAge(); //按照年龄升序排序 } }); System.out.println(list); //[Student{name='Tom', age=18}, Student{name='Alice', age=19}, Student{name='Jerry', age=20}] 以上就是JavaList.sort()方法的使用方法。 ### 回答2: JavaList是一种存储对象的集合。List的元素是按照顺序存储的,可以对其的元素进行排序操作,常用的排序方法有Collections.sort()和List.sort()两个方法,其List.sort()是Java 8新增的方法List.sort()方法的使用非常简单,只需要将需要进行排序的List对象调用该方法即可,如下所示: ``` List<String> list = new ArrayList<>(); list.add("apple"); list.add("banana"); list.add("cherry"); list.sort(null); ``` 上面的代码,创建了一个存储字符串类型元素的List对象,然后添加了三个元素。最后调用list.sort(null)方法进行排序。在上面的代码,null表示使用默认的排序规则,如果需要自定义排序规则,可以通过传递一个Comparator对象进行排序。 按照自然顺序排序: ``` List<Integer> list = new ArrayList<>(); list.add(3); list.add(1); list.add(2); list.sort(null); ``` 按照自定义顺序排序: ``` List<Person> list = new ArrayList<>(); list.add(new Person("Tom", 20)); list.add(new Person("Jack", 18)); list.add(new Person("Lucy", 19)); list.sort((o1, o2) -> o1.getAge() - o2.getAge()); ``` 在上面的代码,创建了一个存储Person对象的List对象,然后通过lambda表达式传递一个Comparator对象,按照Person对象的age属性进行排序。 总之,List.sort()方法使用非常方便,只需要传递一个Comparator对象即可进行自定义排序,该方法Java 8新增的功能,使用起来非常简洁和易懂。 ### 回答3: JavaList是一种集合框架,它被用于存储一组有序的元素。List的数据元素可以是任何对象类型,如基本类型、字符串、自定义类等。JavaList提供了一种排序的方法sort(),用于对List的元素进行排序。 List.sort()方法Java 8新增的方法,主要是用于对List集合的元素进行排序。这个方法接收一个java.util.Comparator参数,用于自定义排序规则。Comparator是一个接口,可以通过实现它来创建排序规则。 List.sort()方法可以使用默认的排序规则,也可以使用自定义的排序规则。如果使用默认的排序规则,List.sort()方法将按升序排序元素。如果使用自定义的排序规则,List.sort()方法将按照自定义的规则对元素进行排序。如果元素不能进行比较,例如某个元素为null,则List.sort()方法将引发NullPointerException异常。 下面是使用List.sort()方法进行排序的一些示例: 1、使用默认排序规则进行排序: List<Integer> list = new ArrayList<>(Arrays.asList(3, 1, 4, 2, 5)); list.sort(null); // 使用默认的升序排序规则 System.out.println(list); // 输出:[1, 2, 3, 4, 5] 2、使用自定义排序规则进行排序: List<String> list = new ArrayList<>(Arrays.asList("aaa", "bb", "cccc", "ddddd", "e")); list.sort((s1, s2) -> s1.length() - s2.length()); // 按照字符串长度升序排序 System.out.println(list); // 输出:[e, bb, aaa, cccc, ddddd] 3、使用Comparator.comparing()方法进行排序: List<Student> list = new ArrayList<>(Arrays.asList(new Student("张三", 18), new Student("李四", 20), new Student("王五", 15))); list.sort(Comparator.comparing(Student::getAge)); // 按照年龄升序排序 System.out.println(list); // 输出:[Student{name='王五', age=15}, Student{name='张三', age=18}, Student{name='李四', age=20}] 综上所述,List.sort()方法JavaList集合进行排序的一种快捷方式,它可以使用默认的排序规则或自定义的排序规则来对List的元素进行排序。在使用List.sort()方法时,需要注意元素的比较是否有异常情况的出现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值