Heim >Java >javaLernprogramm >Beispielcode, wie Collections.sort() die Listensortiermethode in Java implementiert
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 ShuoWang Shuo Liu Yuanyuan Liu Di Liu Bu Li Ming
2. Benutzerdefinierte Sortierregeln:
Die erste ist, dass die Modellklasse Comparable implementiertSchnittstelle , 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's comparation depend on types' 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!