java treeset类的排序规则_Java中的集合框架之TreeSet排序规则

Java中的集合框架之TreeSet排序规则

1、TreeSet排序规则

TreeSet集合是一个可以指定元素顺序,即:TreeSet集合是有序的集合类。默认情况下,TreeSet集合的排序规则是自然排序。

自然排序:就是元素自身具备的比较性实现了Comparable接口的compareTo()方法。

2、自定义排序规则

当我们使用TreeSet集合存储自定义对象时,这时候如果不自定义排序规则,则程序会抛出异常。如下图所示:

3dea67c93b7716e93327328345b32ed9.png

2.1、第一种排序方式

自定义排序规则,需要将自定义对象类实现Comparable接口,并且实现其中的compareTo()方法,在该方法中定义自定义排序规则。

e8093e70e764d9872d4e319b1095ed23.png

b327223a67ab9e127c23cb7910c9527f.png

测试案例:

87c8bec182f4c461562fbce1fd0601c2.png

3fbb1590b25edeeda867a75207ec025b.png

2.2、第二种排序方式

这种排序方式是在TreeSet的构造方法中,传递一个比较器Comparator。该比较器定义了排序规则。

当构造方法被初始化时,就会根据比较器的排序规则,将集合中的元素进行排序。

使用第二种排序方式,需要实现Comparator接口,并且实现compare()方法,该方法是定义排序规则的。

一般来说,最好使用匿名内部类的方式,实现Comparator接口。

071681689370dd5a0c93d5c7a48e878c.png

913354f0ba74aea48fa918e07673aae9.png

注:compare()方法的返回值是一个int值。

当返回值大于0时,o1大于o2。

当返回值等于0时,o1等于o2。

当返回值小于0时,o1小于o2。

综上,Java中集合框架之TreeSet集合排序规则介绍完了。

这是我的第43篇文章,谢谢大家阅读。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值