Collections工具类的使用

public class Demo9 {
public static void main(String[] args) {
/*
* Collections:集合工具类,封装了操作集合的方法

* 要求:存储多个数据,数据可以重复,必须排序.
* 分析:借助Collections让ArrayList实现重复但是可以排序
*/

ArrayList<String> list = new ArrayList<>();
list.add("javaeee");
list.add("php");
list.add("python");
list.add("iOS");
list.add("html");
//按照添加的顺序排序---自然顺序
System.out.println(list);

//字典排序--升序排序
Collections.sort(list);
//注意:这里要想实现排序,元素必须实现了Comparable接口的compareTo方法
System.out.println("字典排序:"+list);


//按照字符串的长短排序
//先按照从短到长排--默认的方法无法实现,所以要创建自己的比较器,指定自己的比较规则
ComWithLength comWithLength = new ComWithLength();

//按照指定的比较器比较
Collections.sort(list,comWithLength);
System.out.println("从短到长排序:"+list);

//从长到短
//利用现有的比较器反转得到新的比较器--从长到短
Comparator<String> comparator1 =  Collections.reverseOrder(comWithLength);
Collections.sort(list,comparator1);
System.out.println("从长到短排序:"+list);

//字典顺序的反转比较器
Comparator<String> comparator2 =  Collections.reverseOrder();
Collections.sort(list,comparator2);
System.out.println("字典顺序反转排序:"+list);

//现有顺序的反转
Collections.reverse(list);
System.out.println("现有顺序的反转:"+list);

//求最大值
//默认按照字典排序求最大值:
String max = Collections.max(list);
System.out.println("最大值:"+max);

//按照指定的顺序排序
String max1 = Collections.max(list, comWithLength);
System.out.println(max1);
}
}


class ComWithLength implements Comparator<String>{
public int compare(String o1, String o2) {
   //先按照长度排,长度相同再按照字典顺序排
int num = o1.length()-o2.length();
return num==0?o1.compareTo(o2):num;
}

}




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值