Eu tenho uma aula chamada Fruit. Estou a criar uma lista desta classe e a adicionar cada fruta da lista. Quero ordenar esta lista com base na ordem do nome da fruta.
public class Fruit{
private String fruitName;
private String fruitDesc;
private int quantity;
public String getFruitName() {
return fruitName;
}
public void setFruitName(String fruitName) {
this.fruitName = fruitName;
}
public String getFruitDesc() {
return fruitDesc;
}
public void setFruitDesc(String fruitDesc) {
this.fruitDesc = fruitDesc;
}
public int getQuantity() {
return quantity;
}
public void setQuantity(int quantity) {
this.quantity = quantity;
}
}
e eu estou criando sua lista usando para loop
List<Fruit> fruits= new ArrayList<Fruit>();
Fruit fruit;
for(int i=0;i<100;i++)
{
fruit = new fruit();
fruit.setname(...);
fruits.add(fruit);
}
e preciso ordenar esta matrizLista usando o nome da fruta de cada objeto da lista
Como?
Utilize um Comparador
como este:
List<Fruit> fruits= new ArrayList<Fruit>();
Fruit fruit;
for(int i = 0; i < 100; i++)
{
fruit = new Fruit();
fruit.setname(...);
fruits.add(fruit);
}
// Sorting
Collections.sort(fruits, new Comparator<Fruit>() {
@Override
public int compare(Fruit fruit2, Fruit fruit1)
{
return fruit1.fruitName.compareTo(fruit2.fruitName);
}
});
Agora a sua lista de frutas é classificada com base no fruitName
.
Implementar Interface comparável para a Fruit.
public class Fruit implements Comparable<Fruit> {
Ele implementa o método
@Override
public int compareTo(Fruit fruit) {
//write code here for compare name
}
Então, ligue para o método de ordenação
Collections.sort(fruitList);
Tente BeanComparator do Apache Commons.
import org.apache.commons.beanutils.BeanComparator;
BeanComparator fieldComparator = new BeanComparator("fruitName");
Collections.sort(fruits, fieldComparator);