将set集合转为list并对对象进行排序

之前用hibernate的时候,遇到一对多的表结构。比如班级(class),学生(student)时,hibernate都是将student作为一个set集合放在班级对象之中,这是无序的,而我们往往要根据student的id或者分数进行排序。以前采用的办法很笨,遍历set,再借助数组将其按照所要求的顺序加入到list中。这两天发现一种比较好的方法如下:



public class Stude implements Comparable<Object> {


private String id;
private String name;
private String address;

public Stude() {
}
public Stude(String id,String name,String address) {
this.id=id;
this.name=name;
this.address=address;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}

@Override
public int compareTo(Object arg0) {
Stude stu1=(Stude)arg0;
/*根据id排序
* int stu0Id=Integer.parseInt(id);
int stu1Id=Integer.parseInt(stu1.id);
return stu0Id>stu1Id?1:(stu0Id==stu1Id?0:-1);*/
return name.compareTo(stu1.getName());//根据name排序
}


}



import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Set;


public class Test {




public static void main(String[] args) {
Stude stu=new Stude("1","gao","hz");
Stude stu2=new Stude("2","aao","hz");
Stude stu3=new Stude("3","zao","hz");

Set<Stude> studeset=new HashSet<Stude>();
studeset.add(stu);
studeset.add(stu2);
studeset.add(stu3);
List<Stude> stuList=new ArrayList<Stude>();
stuList.addAll(studeset);
Collections.sort(stuList);
for (Stude stude : stuList) {
System.out.println(stude.getName());
}
}


}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值