cannot be cast to java.lang.Comparable解决办法

对于TreeMap,他是一个有序的map,当你将key put到treeMap中,它会根据你所提供的排序规则进行排序插入,如果没有提供,则使用默认。

cannot be cast to java.lang.Comparable,遇到这个异常错误,就是说treeMap并不知道该如何put,就会报这个异常错误。第一次put时,因为为空,所以不需要比较,即不会报错。但是当第二次put时,treeMap为了确保他是有序的就必须比较,这个时候发现这两个key根本无法比较,则抛出该异常错误。

要解决这个异常错误有两种解决办法。第一种在构造TreeMap时指定一个比较器,这个比较器用于比较两个值,并且返回一个整数值作为他们的比较结果。第二种就是key实现Comparable接口。

下面实例是我做毕业设计过程中,对订单进行排序使用的TreeMap构造器:

/**
          * 获取指定构造器的TreeMap对象
          */
         publicMap<Order, List<OrderDetail>> getTreeMap(){
                   Map<Order,List<OrderDetail>> map = new TreeMap<Order,List<OrderDetail>>(
                                     //比较器按照降序实现
                                     (Comparator<?super Order>) new Comparator<Order>(){
                                               publicint compare(Order order1, Order order2) {
                                                        returnorder2.getOrderId().compareTo(order1.getOrderId());
                                               }
                                     }
                   );
                   returnmap;
         }


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值