文章详情页
java如何对不同的类对象进行排序
浏览:69日期:2023-11-01 18:59:08
问题描述
假设两个类A,B有共同的属性date,我要对两个List<A>, List<B>, 按照date进行排序,怎么做比较好?
我知道的方法是写一个基类,然后A和B继承这个基类,然后再调用Collections.sort()排序.
请问有没有更好的办法,或者是使用反射写一个类似的方法?亦或是有现成的库可以使用?
问题解答
回答1:使用上面你说的是较好的方法,1.可以利用java本身提供的api减少了代码量,2.上面的方式在代码风格上也蛮好的。还有一种思路是将每A,B类的date提出来并与A,B对象本身建立关联,比如实现一个类Index,Index中有两个属性,date和A,B类对象的引用或者id,每个A,B类对象关联一个Index对象,然后对Index对象排序,然后通过id找到对应A或B的对象,同index对象一样的顺序,即排好序。
回答2:list.sort((l1,l2) -> l1.getDate().compareTo(l2.getDate()));回答3:
弄一个Base Class,A、B extends之
弄一个Interface,A、B implements之
弄一个List<Object>,然后sort之,Comparator里面需要强转类型
弄一个Wrapper class,包装A、B,然后放在List中,sort之
标签:
java
相关文章:
1. mysql - 一个表和多个表是多对多的关系,该怎么设计2. html5 - iOS的webview加载出来的H5网页,怎么修改html标签select的样式字体?3. python 如何实现PHP替换图片 链接4. 一个mysql联表查询的问题5. angular.js - 三大框架react、vue、angular的分析6. mysql优化 - mysql count(id)查询速度如何优化?7. python如何不改动文件的情况下修改文件的 修改日期8. javascript - git clone 下来的项目 想在本地运行 npm run install 报错9. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?10. 主从备份 - 跪求mysql 高可用主从方案
排行榜
