使用treeSet报cannot be cast to java.lang.Comparable

treeSet的特点:不可重复可排序

使用treeSet进行排序的时候,需要注意的地方:

1、在使用treeSet进行排序的时候,如果数据不能排序会报cannot be cast to java.lang.Comparable

2、对于不能排序的数据,有两种方法可以实现排序:

a、对于排序的实体类实现java.lang.comparable接口重写compareTo方法

public class Person implements Comparable<Person> {
	
	//姓名
	private String name;
	//帅气指数
	private int handsome;
	public Person() {
	}
	public Person(String name, int handsome) {
		super();
		this.name = name;
		this.handsome = handsome;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getHandsome() {
		return handsome;
	}
	public void setHandsome(int handsome) {
		this.handsome = handsome;
	}
	
	@Override
	public String toString() {
		return "姓名:"+this.name+"\t帅气指数:"+this.handsome;
	}
	@Override
	public int compareTo(Person o) {
		//根据帅气指数进行降序排序,若要进行升序在前面加一个负号
		return (o.handsome - this.handsome);
	}

}
b、新增一个业务类实现java.util.comparator接口重写compare方法

public class PersonSort implements java.util.Comparator<Person> {

	@Override
	public int compare(Person o1, Person o2) {
		/*
		 * 根据帅气指数进行升序排序,如果要降序则在前面加一个负号
		 * 怎么使用:在new TreeSet(new PersonSort());
		 */
		return (o1.getHandsome()-o2.getHandsome());
	}

}
使用treeSet需要注意的地方:

1、使用treeSet在排序的时候是在添加的时候进行排序的,如果在添加之后修改数据不会影响前面的排序

2、在使用treeSet的时候,如果是在添加数据之后修改数据的值,可能会出现一样的数据

3、为了避免这种情况的发生,可以将对象的属性用final修饰


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
根据错信息,看起来在使用 `Collectors.collectingAndThen()` 方法时,出现了将数组对象 `[Ljava.lang.Object;` 转换为 `MRegistMain` 的错误。这通常是由于查询结果集返回的类型不正确导致的。 您可以尝试使用 `Stream.map()` 方法来显式地将数组对象转换为 `MRegistMain` 对象。以下是修改后的代码示例: ```java import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.TreeSet; import java.util.stream.Collectors; // ... List<MRegistMain> mRegistMains = mPolicyMainDao.getRegistMainList(aggreeNo, name, identifyNo); if (mRegistMains != null && !mRegistMains.isEmpty()) { List<MRegistMain> sortedAndDistinctMRegistMains = mRegistMains.stream() .map(obj -> (MRegistMain) obj) // 将数组对象转换为 MRegistMain 对象 .collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(MRegistMain::getRegistno))), ArrayList::new)); // sortedAndDistinctMRegistMains 即为去重且按照 getRegistno 属性排序后的列表 log.info("官网历史理赔查询结果集:: {}", sortedAndDistinctMRegistMains); } else { // 处理结果集为空的情况 } ``` 通过在 `map()` 方法中进行类型转换,将数组对象转换为 `MRegistMain` 对象。然后再进行去重和排序操作。 请注意,这只是一个示例代码片段,具体实现可能需要根据您的业务逻辑进行调整。希望能帮到您!如果您还有任何问题,请随时提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

修炼之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值