Heim >Java >javaLernprogramm >Beispielcode, wie Collections.sort() die Listensortiermethode in Java implementiert

Beispielcode, wie Collections.sort() die Listensortiermethode in Java implementiert

黄舟
黄舟Original
2017-06-18 10:10:101964Durchsuche

In diesem Artikel werden hauptsächlich die Standard- und benutzerdefinierten Methoden von Java Collections.sort () zum Implementieren der Listensortierung vorgestellt. Freunde in Not können sich auf

1 Die von Java bereitgestellte Standard-Listensortiermethode beziehen 🎜>

Hauptcode:


List<String> list = new ArrayList();list.add("刘媛媛");
list.add("王硕");
list.add("李明");
list.add("刘迪");
list.add("刘布");
//升序
Collections.sort(list,Collator.getInstance(java.util.Locale.CHINA));//注意:是根据的汉字的拼音的字母排序的,而不是根据汉字一般的排序方法
for(int i=0;i<list.size();i++)
{
 System.out.print(list.get(i));
}
System.out.println("");
//降序
Collections.reverse(list);//不指定排序规则时,也是按照字母的来排序的
for(int i=0;i<list.size();i++)
{
  System.out.print(list.get(i));
}
Ausgabeergebnis:

Li Ming Liu Bu Liu Di Liu Yuanyuan Wang Shuo

Wang Shuo Liu Yuanyuan Liu Di Liu Bu Li Ming

2. Benutzerdefinierte Sortierregeln:

Die erste ist, dass die Modellklasse Comparable implementiert

Schnittstelle , override override int CompareTo(Object o) Methode

        Modellklasse:


public class StudentDTO implements Comparable
{
 private String name;
 private int age;
public String getName()
{
 return name;
}
public void setName(String name)
{
  this.name = name;
}
public ObjType getType()
{
 return type;
}
public void setAge(int age)
{
  this.age= age;
}
@Override
public int compareTo(Object o)
{
  StudentDTO sdto = (StudentDTO)o;
  int otherAge = sdto.getAge();
  // note: enum-type&#39;s comparation depend on types&#39; list order of enum method
  // so, if compared property is enum-type ,then its comparationfollow ObjEnum.objType order
  return this.age.compareTo(otherAge);
}
}
   主方法:   
public static void main(String[] args)
{
  List<StudentDTO> studentList = new ArrayList();
  StudentDTO s1 = new StudentDTO ();
  s.setName("yuanyuan");
  s.setAge(22);
  studentList.add(s1);
     StudentDTO s1 = new StudentDTO ();
     s.setName("lily");
     s.setAge(23);
     studentList.add(s2);
     Collections.sort(studentList); //按照age升序 22,23,
     Collections.reverse(studentList); //按照age降序 23,22 
}
Die zweite Typ ist, dass die Komparatorklasse die Comparator-Schnittstelle implementiert und die int-Vergleichsmethode (Objekt o1, Objekt o2)

Modellklasse überschreibt: Hinweis:

1 Array

lautet wie folgt:

public class StudentDTO implements Comparable
{
  private String name;
  private int age;
  public String getName()
  {
   return name;
  }
  public void setName(String name)
 {
   this.name = name;
  }
  public ObjType getType()
  {
   return type;
  }
  public void setAge(int age)
  {
   this.age= age;
  }
} 
   比较器类:
class MyCompartor implements Comparator
{
  @Override
  public int compare(Object o1, Object o2)
 {
   StudentDTO sdto1= (StudentDTO )o1;
   StudentDTO sdto2= (StudentDTO )o2;
   return sdto1.getAge.compareTo(stdo2.getAge())
 }
}
   主方法:
public static void main(String[] args)
{
  List<StudentDTO> studentList = new ArrayList();
  StudentDTO s1 = new StudentDTO ();
  s.setName("yuanyuan");
  s.setAge(22);
  studentList.add(s1);
  StudentDTO s1 = new StudentDTO ();
  s.setName("lily");
  s.setAge(23);
  studentList.add(s2);
  MyComparetor mc = new MyComparetor();
  Collections.sort(studentList,mc);  //按照age升序 22,23,
  Collections.reverse(studentList,mc); //按照age降序 23,22 
}

2. Zum Sortieren chinesischer Zeichen: Sie können versuchen, bessere Ergebnisse zu erzielen, insbesondere wenn der Nachname einige ist seltene Zeichen, Ersetzen Sie java.text.Collator durch com.ibm.icu.text.Collator und com.ibm.icu util.ULocale ersetzt java.util.Locale

3 Aufzählungstypen, enum1.compareTo (enum2) werden entsprechend der Reihenfolge verglichen, in der die Aufzählungstypwerte definiert sind. Die späteren Werte sind größer, anstatt in alphabetischer Reihenfolge der Werte zu vergleichen.

Das obige ist der detaillierte Inhalt vonBeispielcode, wie Collections.sort() die Listensortiermethode in Java implementiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn