java实现对象比较,可以实现java.lang.Comparable或java.util.Comparator接口

  1. //Product.java
  2. import java.util.Date;
  3. //public class Product implements Comparable {//类内比较
  4. public class Product{
  5. private String name;
  6. private Date date;
  7. private int price;
  8. public int getPrice() {
  9. return price;
  10. }
  11. public void setPrice(int price) {
  12. this.price = price;
  13. }
  14. public String getName() {
  15. return name;
  16. }
  17. public void setName(String name) {
  18. this.name = name;
  19. }
  20. public Date getDate() {
  21. return date;
  22. }
  23. public void setDate(Date date) {
  24. this.date = date;
  25. }
  26. //用于类内比较
  27. //  @Override//覆写compareTo(Object o)方法
  28. //  public int compareTo(Product o) {
  29. //      return -this.date.compareTo(o.date);
  30. //  }
  31. }
  1. //ProductComparable.java
  2. import java.util.Date;
  3. import java.util.Comparator;
  4. public class ProductComparable implements Comparator<Product> {
  5. // 对象的排序方式[升、降]
  6. public static boolean sortASC = true;
  7. // 对象的排序属性
  8. public static boolean sortByName = false;
  9. public static boolean sortByDate = false;
  10. public static boolean sortByPrice = false;
  11. @Override
  12. public int compare(Product pro1, Product pro2) {
  13. int result = 0;
  14. if(sortASC){
  15. if(sortByName){
  16. String pro1name = pro1.getName();
  17. String pro2name = pro2.getName();
  18. result = pro1name.compareTo(pro2name);
  19. }else if(sortByDate){
  20. Date pro1Date = pro1.getDate();
  21. Date pro2Date = pro2.getDate();
  22. result = pro1Date.compareTo(pro2Date);
  23. }else if(sortByPrice){
  24. Integer pro1Price = pro1.getPrice();
  25. Integer pro2Price = pro2.getPrice();
  26. result = pro1Price.compareTo(pro2Price);
  27. }
  28. }else{
  29. if(sortByName){
  30. String pro1name = pro1.getName();
  31. String pro2name = pro2.getName();
  32. result =  -pro1name.compareTo(pro2name);
  33. }else if(sortByDate){
  34. Date pro1Date = pro1.getDate();
  35. Date pro2Date = pro2.getDate();
  36. result =  -pro1Date.compareTo(pro2Date);
  37. }else if(sortByPrice){
  38. Integer pro1Price = pro1.getPrice();
  39. Integer pro2Price = pro2.getPrice();
  40. result =  -pro1Price.compareTo(pro2Price);
  41. }
  42. }
  43. return result;
  44. }
  45. }
  1. //测试代码
  2. import java.text.ParseException;
  3. import java.text.SimpleDateFormat;
  4. import java.util.ArrayList;
  5. import java.util.Collections;
  6. import java.util.Iterator;
  7. import java.util.List;
  8. import java.util.Locale;
  9. public class ProductSort {
  10. public static void main(String[] args) throws ParseException {
  11. Product pro1 = new Product();
  12. pro1.setName("pro1");
  13. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-dd-MM",Locale.CHINA);
  14. pro1.setDate(sdf.parse("2009-03-23"));
  15. pro1.setPrice(89);
  16. Product pro2 = new Product();
  17. pro2.setName("proc2");
  18. pro2.setDate(sdf.parse("2009-02-23"));
  19. pro2.setPrice(45);
  20. Product pro3 = new Product();
  21. pro3.setName("proc3");
  22. pro3.setDate(sdf.parse("2009-01-23"));
  23. pro3.setPrice(83);
  24. Product pro4 = new Product();
  25. pro4.setName("proc4");
  26. pro4.setDate(sdf.parse("2009-01-23"));
  27. pro4.setPrice(800);
  28. List<Product> productList = new ArrayList<Product>();
  29. productList.add(pro1);
  30. productList.add(pro3);
  31. productList.add(pro2);
  32. productList.add(pro4);
  33. System.out.println("排序前————————————————————");
  34. for(Product p: productList){
  35. System.out.println(p.getName()+"----"+p.getPrice()+"----"+p.getDate());
  36. }
  37. ProductComparable sort = new ProductComparable();
  38. ProductComparable.sortASC = false;//降序
  39. ProductComparable.sortByPrice=true;  //设置排序属性生效
  40. Collections.sort(productList,sort);
  41. System.out.println("排序后————————————————————");
  42. for(Iterator<Product>  iter = productList.iterator(); iter.hasNext();){
  43. Product p = (Product)iter.next();
  44. System.out.println(p.getName()+"----"+p.getPrice()+"---"+p.getDate());
  45. }
  46. }
  47. }

推荐使用Comparator实现排序

因为 你用一个第三方的类,但他没实现Comparable接口,而你又不能改他代码;另外,类一旦写好后是不允许修改的,但可以扩展,所以只能用Comparator接口

java实现对象比较,可以实现java.lang.Comparable或java.util.Comparator接口

  1. //Product.java
  2. import java.util.Date;
  3. //public class Product implements Comparable {//类内比较
  4. public class Product{
  5. private String name;
  6. private Date date;
  7. private int price;
  8. public int getPrice() {
  9. return price;
  10. }
  11. public void setPrice(int price) {
  12. this.price = price;
  13. }
  14. public String getName() {
  15. return name;
  16. }
  17. public void setName(String name) {
  18. this.name = name;
  19. }
  20. public Date getDate() {
  21. return date;
  22. }
  23. public void setDate(Date date) {
  24. this.date = date;
  25. }
  26. //用于类内比较
  27. //  @Override//覆写compareTo(Object o)方法
  28. //  public int compareTo(Product o) {
  29. //      return -this.date.compareTo(o.date);
  30. //  }
  31. }
  1. //ProductComparable.java
  2. import java.util.Date;
  3. import java.util.Comparator;
  4. public class ProductComparable implements Comparator<Product> {
  5. // 对象的排序方式[升、降]
  6. public static boolean sortASC = true;
  7. // 对象的排序属性
  8. public static boolean sortByName = false;
  9. public static boolean sortByDate = false;
  10. public static boolean sortByPrice = false;
  11. @Override
  12. public int compare(Product pro1, Product pro2) {
  13. int result = 0;
  14. if(sortASC){
  15. if(sortByName){
  16. String pro1name = pro1.getName();
  17. String pro2name = pro2.getName();
  18. result = pro1name.compareTo(pro2name);
  19. }else if(sortByDate){
  20. Date pro1Date = pro1.getDate();
  21. Date pro2Date = pro2.getDate();
  22. result = pro1Date.compareTo(pro2Date);
  23. }else if(sortByPrice){
  24. Integer pro1Price = pro1.getPrice();
  25. Integer pro2Price = pro2.getPrice();
  26. result = pro1Price.compareTo(pro2Price);
  27. }
  28. }else{
  29. if(sortByName){
  30. String pro1name = pro1.getName();
  31. String pro2name = pro2.getName();
  32. result =  -pro1name.compareTo(pro2name);
  33. }else if(sortByDate){
  34. Date pro1Date = pro1.getDate();
  35. Date pro2Date = pro2.getDate();
  36. result =  -pro1Date.compareTo(pro2Date);
  37. }else if(sortByPrice){
  38. Integer pro1Price = pro1.getPrice();
  39. Integer pro2Price = pro2.getPrice();
  40. result =  -pro1Price.compareTo(pro2Price);
  41. }
  42. }
  43. return result;
  44. }
  45. }
  1. //测试代码
  2. import java.text.ParseException;
  3. import java.text.SimpleDateFormat;
  4. import java.util.ArrayList;
  5. import java.util.Collections;
  6. import java.util.Iterator;
  7. import java.util.List;
  8. import java.util.Locale;
  9. public class ProductSort {
  10. public static void main(String[] args) throws ParseException {
  11. Product pro1 = new Product();
  12. pro1.setName("pro1");
  13. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-dd-MM",Locale.CHINA);
  14. pro1.setDate(sdf.parse("2009-03-23"));
  15. pro1.setPrice(89);
  16. Product pro2 = new Product();
  17. pro2.setName("proc2");
  18. pro2.setDate(sdf.parse("2009-02-23"));
  19. pro2.setPrice(45);
  20. Product pro3 = new Product();
  21. pro3.setName("proc3");
  22. pro3.setDate(sdf.parse("2009-01-23"));
  23. pro3.setPrice(83);
  24. Product pro4 = new Product();
  25. pro4.setName("proc4");
  26. pro4.setDate(sdf.parse("2009-01-23"));
  27. pro4.setPrice(800);
  28. List<Product> productList = new ArrayList<Product>();
  29. productList.add(pro1);
  30. productList.add(pro3);
  31. productList.add(pro2);
  32. productList.add(pro4);
  33. System.out.println("排序前————————————————————");
  34. for(Product p: productList){
  35. System.out.println(p.getName()+"----"+p.getPrice()+"----"+p.getDate());
  36. }
  37. ProductComparable sort = new ProductComparable();
  38. ProductComparable.sortASC = false;//降序
  39. ProductComparable.sortByPrice=true;  //设置排序属性生效
  40. Collections.sort(productList,sort);
  41. System.out.println("排序后————————————————————");
  42. for(Iterator<Product>  iter = productList.iterator(); iter.hasNext();){
  43. Product p = (Product)iter.next();
  44. System.out.println(p.getName()+"----"+p.getPrice()+"---"+p.getDate());
  45. }
  46. }
  47. }

推荐使用Comparator实现排序

因为 你用一个第三方的类,但他没实现Comparable接口,而你又不能改他代码;另外,类一旦写好后是不允许修改的,但可以扩展,所以只能用Comparator接口

Java对象排序的更多相关文章

  1. Java 对象排序详解

    很难想象有Java开发人员不曾使用过Collection框架.在Collection框架中,主要使用的类是来自List接口中的ArrayList,以及来自Set接口的HashSet.TreeSet,我 ...

  2. java对象排序(Comparable)详细实例

    对象实现Comparable接口 public class Field implements Comparable<Field>{ private String name; private ...

  3. [Java] 对象排序示例

    package test.collections; import java.util.ArrayList; import java.util.Collection; import java.util. ...

  4. Java对象排序两种方法

    转载:https://blog.csdn.net/wangtaocsdn/article/details/71500500 有时候需要对对象列表或数组进行排序,下面提供两种简单方式: 方法一:将要排序 ...

  5. 多字段 java对象排序

    public class ReflexUtil { static Logger logger = LoggerFactory.getLogger(ReflexUtil.class); //getMet ...

  6. Java笔记12:Java对象排序

    代码: import java.util.Arrays; import java.util.Comparator; class Person { private String name; privat ...

  7. Java - 简单的对象排序 - Comparator

    注:对象排序,就是对对象中的某一字段进行比较,以正序或倒序进行排序. 例: 需要排序的对象: public class Person { public int age; public String n ...

  8. [个人原创]关于java中对象排序的一些探讨(三)

    这篇文章由十八子将原创,转载请注明,并标明博客地址:http://www.cnblogs.com/shibazijiang/ 对对象排序也可以使用Guava中的Ordering类. 构造Orderin ...

  9. Java集合中对象排序

    集合中的对象排序需求还是比較常见的.当然我们能够重写equals方法,循环比較:同一时候Java为我们提供了更易使用的APIs.当须要排序的集合或数组不是单纯的数字型时,通常能够使用Comparato ...

随机推荐

  1. java在继承中父类的成员变量是否会被子类所覆盖

    假如 父类 int num =7:子类 int num =9:父类是否会被子类所覆盖? 给你看两个例子: 第一个例子: 第二个例子: 这两个例子的区别只有一句话   由此证明了子类从父类继承的时候   ...

  2. recording just for inquiry in the future

    auditd审计 相关命令有: auditd, auditctl, ausearch, aureport 相关文件: /etc/audit/auditd.conf, /etc/audit/audit. ...

  3. SASS的一些使用体会(安装-配置-开启firefox的调试)

    对CSS预处理这个东西的看法,基本就是2种 第一种:不就是css吗,我会写就好了搞得那么复杂干嘛 第二种:感觉这个东西非常有必要,它规范了代码,使开发变得更轻松 好吧以前我是第一种,并且觉得又要配置环 ...

  4. 移动WebApp利用Chrome浏览器进行调试

    详细的请看这个(HBuilder是我长期使用,而且值得支持的国内前端开发编辑器) http://ask.dcloud.net.cn/article/151 http://ask.dcloud.net. ...

  5. [转载]SVN如何恢复已删除文件或文件夹

    http://blog.sina.com.cn/s/blog_694d806e0100kaqz.html 用TortoiseSVN: 1.在本地working copy中,用TortoiseSVN-& ...

  6. 黄学长模拟day1 球的序列

    N个编号为1-n的球,每个球都有唯一的编号.这些球被排成两种序列,分别为A.B序列,现在需要重新寻找一个球的序列l,对于这个子序列l中任意的两个球,要求j,k(j<k),都要求满足lj在A中位置 ...

  7. R语言练习(二)

    op <- par(mfrow = c(2, 2)) #设置画布 p2 <- curve(x^2, 0, 1) #绘制曲线 legend("topleft", inse ...

  8. codeblocks+Mingw 下配置开源c++单元测试工具 google test

    google test 是google的c++开源单元测试工具,chrome的开发团队就是使用它. Code::Blocks 12.11(MinGW 4.7.1) (Windows版)Google T ...

  9. Java网络编程学习

    服务器是指提供信息的计算机或程序,客户机是指请求信息的计算机或程序,而网络用于连接服务器与客户机,实现两者相互通信.但有时在某个网络中很难将服务器与客户机区分开.我们通常所说的“局域网”(Local ...

  10. C++中的内联成员函数与非内联成员函数

    在C++中内联成员函数与非内联成员函数的可以分为两种情况: 1.如果成员函数的声明和定义是在一起的,那么无论有没有写inline这个成员函数都是内联的,如下: using namespace std; ...