基于java中的不同数据成员对对象列表进行排序

Bra*_*esh 3 java sorting string collections comparable


我有这门课:

public class Friend {

private String name;
private String location;
private String temp;
private String humidity;

public String getTemp() {
    return temp;
}

public void setTemp(String temp) {
    this.temp = temp;
}

public String getHumidity() {
    return humidity;
}

public void setHumidity(String humidity) {
    this.humidity = humidity;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}


public String getLocation() {
    return location;
}

public void setLocation(String location) {
    this.location = location;
}
}
Run Code Online (Sandbox Code Playgroud)

我想根据用户输入根据名称,位置,温度和湿度对List进行排序.
编辑:用户指定必须由哪个数据成员进行排序.
最简单的方法是什么?
谢谢.

FTh*_*son 6

因为您希望按照四种不同的标准对它们进行排序,所以实现Comparable没有意义.在这种情况下,您可能会发现为每个排序参数创建不同的比较器.但是,您可以为最合乎逻辑的排序字段实现Comparable,例如name.否则,比较器是可行的方法.

public class FriendNameComparator extends Comparator<Friend> {

    // assuming both are non-null for code simplicity; you may wish to change that
    public int compare(Friend f1, Friend f2) {
        return f1.getName().compareTo(f2.getName());
    }
}

public class FriendLocationComparator extends Comparator<Friend> {

    // assuming both are non-null for code simplicity; you may wish to change that
    public int compare(Friend f1, Friend f2) {
        return f1.getLocation().compareTo(f2.getLocation());
    }
}

// and so forth
Run Code Online (Sandbox Code Playgroud)

然后,您可以使用Collections实用程序类的sort函数按给定的比较器进行排序.

Collections.sort(friendsList, new FriendNameComparator()); // sorts by name
Collections.sort(friendsList, new FriendLocationComparator()); // sorts by location
// etc
Run Code Online (Sandbox Code Playgroud)


mae*_*ics 5

Java有一个静态函数Collections.sort(List, Comparator),在给定自定义Comparator的情况下对其进行排序(一般化)对象列表,给定两个相同类型的对象,确定哪一个在另一个之前排序.

您的任务是编写一个函数,该函数创建一个Comparator,它根据参数和用户指定的排序顺序对对象进行排序.例如:

public Comparator<Friend> getComparator(final String sortBy) {
  if ("name".equals(sortBy)) {
    return new Comparator<Friend>() {
      @Override int compare(Friend f1, Friend f2) 
        return f1.getName().compareTo(f2.getName());
      }
    };
  } else if ("location".equals(sortBy)) {
    return new Comparator<Friend>() {
      @Override int compare(Friend f1, Friend f2) 
        return f1.getLocation().compareTo(f2.getLocation());
      }
    };
  } else if ("temp".equals(sortBy)) {
    // ...
  } else {
    throw new IllegalArgumentException("invalid sort field '" + sortBy + "'");
  }
}
Run Code Online (Sandbox Code Playgroud)