android List深复制(修改复制的list不影响原list)

    public static <E> List<E> deepCopy(List<E> src) {
        try {
            ByteArrayOutputStream byteOut = new ByteArrayOutputStream();
            ObjectOutputStream out = new ObjectOutputStream(byteOut);
            out.writeObject(src);

            ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray());
            ObjectInputStream in = new ObjectInputStream(byteIn);
            @SuppressWarnings("unchecked")
            List<E> dest = (List<E>) in.readObject();
            return dest;
        } catch (Exception e) {
            e.printStackTrace();
            return new ArrayList<E>();
        }
    }

 

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Android开发中,我们经常需要对列表进行排序以便更好地展示数据。常见的做法是使用Collections.sort()或Arrays.sort()方法对列表进行排序。这两个方法都是Java标准库中的排序方法,用于对List或数组进行排序。另外一种常用的方式是使用Comparator接口,通过实现该接口并传入相应的比较方法,来排序列表。以下是一些示例代码: 示例一:使用Collections.sort()方法 ```java List<String> list = new ArrayList<>(); list.add("apple"); list.add("banana"); list.add("orange"); Collections.sort(list); // 对列表进行升序排序 ``` 示例二:使用Comparator接口 ```java List<Person> list = new ArrayList<>(); list.add(new Person("Alice", 25)); list.add(new Person("Bob", 20)); list.add(new Person("Charlie", 30)); Comparator<Person> comparator = new Comparator<Person>() { @Override public int compare(Person p1, Person p2) { return p1.getAge() - p2.getAge(); // 按照年龄升序排列 } }; Collections.sort(list, comparator); // 对列表按照年龄升序排序 ``` 示例三:使用Arrays.sort()方法 ```java String[] array = {"apple", "banana", "orange"}; Arrays.sort(array); // 对数组进行升序排序 ``` 需要注意的是,如果对自定义的对象进行排序,需要在该对象类中实现Comparable接口并传入相应的比较方法,或者使用Comparator接口进行排序。另外,如果需要排序的数据量较大,应考虑使用多线程排序算法以提高排序效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值