现在有个 list<object>,里面放了不同的消息对象 但是不同对象之间都有 isRead 字段和 createTime 字段,isRead 就是未读已读 createTime 就是创建时间 按照未读在前,已读在后,未读和已读里面按照 createTime 排列,新的消息在前,旧的消息在后,v 友们有思路么
</object>
现在有个 list<object>,里面放了不同的消息对象 但是不同对象之间都有 isRead 字段和 createTime 字段,isRead 就是未读已读 createTime 就是创建时间 按照未读在前,已读在后,未读和已读里面按照 createTime 排列,新的消息在前,旧的消息在后,v 友们有思路么
</object> 1 spritewdx Jan 10, 2020 把已读,未读区分开,写个根据 createTime 的比较器,分别用比较器进行排序,排序后合并 |
2 bluehr Jan 10, 2020 1l 正解 |
4 nutting Jan 10, 2020 还真没搞过两个条件比较的,测试一下吧 |
5 Raymon111111 Jan 10, 2020 两个条件的比较器, 搜一下就有. |
6 l8g Jan 10, 2020 如果你能抽出一个父类,实现 Comparable 接口,就非常简单了。 |
7 muyiluop Jan 10, 2020 我猜可以:时间字段转为时间戳,根据是否已读判断,已读的时间字段设置成负数之后正序排,未读的正常倒序排序。 |
9 qiyuey Jan 10, 2020 Compare 有 andThen |
10 qiyuey Jan 10, 2020 `Comparator.comparing(A::isRead).thenComparing(A::createTime)` |
11 dallaslu Jan 10, 2020 把 Bean 抽象为含有 isRead 和 createTime 的接口 MailBoxItem。实现 Comparable 或在外部实现 Comparator。 ```java @Override public int compare(MailBoxItem o1, MailBoxItem o2) { if (!o2.isRead() && o1.isRead()) { return -1; } else if (o2.isRead() && !o1.isRead()) { return 1; } else { return o1.getCreatTime() - o2.getCreateTime(); } } ``` |
13 busfool Jan 10, 2020 via Android 第三方库有这种,搜搜 multi comparator |
14 fatpower Jan 10, 2020 hutool collutil groupby 方法 |
15 PEPEXXX Jan 10, 2020 val sorted = list.sortedWith(compareByDescending(Message::isRead).thenBy(Message:createTime)) |
16 lihongjie0209 Jan 10, 2020 @qiyuey #10 正解 |
17 PEPEXXX Jan 10, 2020 @parorisim #15 未读在前就是 isRead==false 的时候在前,这是一个倒序 createTime 应该也是倒序 纠正一下上面: compareByDescending(Message::isRead).thenByDescending(Message:createTime) |
18 Kiana1 Jan 10, 2020 先分组 再排列 list.stream().collect(Collectors.groupingBy(Message::isRead,Collectors.toList())).forEach((isRead,list)->{ List<Message> collect = list.stream().sorted(Comparator.comparing(Message::getGmtBeginTime).reversed()).collect(Collectors.toList()); }); |
19 KentY Jan 10, 2020 不管已读那个 flag, 就整个按时间排序 ,随便你用 ascending or descending, 然后 filter 出来 the boolean true/false 连接起来就好了 |
20 aguesuka Jan 11, 2020 via Android 9 楼正解,不要管其他得方法 |
21 zunceng Jan 11, 2020 Golang interface 最佳实践之一 |
22 aguesuka Jan 11, 2020 via Android 楼上这么多答案水平堪忧 |
23 yinzhili Jan 11, 2020 先分组,再排序。 Collectors.groupingBy Comparator.comparing |