[Java]Treeset 사용자 정의 정렬 실현
2302 단어 Javacomparator사용자 정의 정렬treeset
package birthday;
import java.util.Calendar;
public class Student {
private String name;
private Calendar birthday;
Student(String aname,Calendar date)
{
name=aname;
birthday=date;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Calendar getBirthday() {
return birthday;
}
public void setBirthday(Calendar birthday) {
this.birthday = birthday;
}
}
package birthday;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Comparator;
import java.util.Set;
import java.util.TreeSet;
public class ComparatorStudent implements Comparator{
@Override
public int compare(Student o1, Student o2) {
// TODO Auto-generated method stub
if (o1.getBirthday().equals(o2.getBirthday()))
{
if (o1.getName().compareTo(o2.getName())>0) return 1;
else if (o1.getName().compareTo(o2.getName())<0) return -1;
else return 0;
}
else if (o1.getBirthday().after(o2.getBirthday()))
return 1;
else
return -1;
}
public static void main(String ars[])
{
Set treeset = new TreeSet(new ComparatorStudent());
Calendar cal1 = Calendar.getInstance();
Calendar cal2 = Calendar.getInstance();
Calendar cal3 = Calendar.getInstance();
Calendar cal4 = Calendar.getInstance();
cal1.set(1991,5,6);
cal2.set(1992,2,5);
cal3.set(1992,10,12);
cal4.set(1992,2,5);
Student stu1 = new Student ("Mike",cal1);
Student stu2 = new Student ("Jack",cal2);
Student stu3 = new Student ("Lucy",cal3);
Student stu4 = new Student ("Lily",cal4);
treeset.add(stu4);
treeset.add(stu3);
treeset.add(stu2);
treeset.add(stu1);
SimpleDateFormat dateformat = new SimpleDateFormat("yyyy-MM-dd");
for (Student s:treeset)
{
System.out.println(s.getName()+" : "+dateformat.format(s.getBirthday().getTime()));
}
}
}
출력 결과:
Mike : 1991-06-06
Jack : 1992-03-05
Lily : 1992-03-05
Lucy : 1992-11-12
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.