SSH中set的排序

本文详细介绍了在使用SSH框架时,如何通过实现Comparable接口和使用TreeSet集合来对Bean层的一对多关系进行有序存储。通过实例演示了如何实现Comparable接口的compareTo方法,并使用TreeSet进行自动排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用ssh框架的时候,bean层反倒出来的一对多,一的那段存的是多的一端的set集合。set是无序的,所以我们要使用TreeSet进行排序,使用步骤大概是:

首先,在我们的bean实现Comparable接口的compareTo()方法;

其次,在使用Set集合的时候不在使用new HashSet()了,而是使用new TreeSet();

只要我们的bean实现了Comparable接口,并且我们存入TreeSet的对象是同一个类型,在存入TreeSet的时候它会自动调用我们的compareTo()方法进行排序,而不需要多余的操作。

小例子:

public class Attendance implements Comparable {

private Integer attId;

public Integer getAttId() {
return this.attId;
}

public void setAttId(Integer attId) {
this.attId = attId;
}

public String toString(){
return " 编号="+this.attId;
}

//实现接口

public int compareTo(Object o) {
Attendance a=(Attendance)o;
return this.attId-a.attId;
}

//测试的main方法
public static void main(String[] args){
Attendance atta=new Attendance();
atta.setAttId(30);
Attendance attb=new Attendance();
attb.setAttId(25);
Attendance attc=new Attendance();
attc.setAttId(23);
Attendance attd=new Attendance();
attd.setAttId(22);
Attendance atte=new Attendance();
atte.setAttId(21);
Set s=new TreeSet(new ArrayList());

s.add(atte);
s.add(atta);
s.add(attc);
s.add(attb);
s.add(attd);
System.out.println(s);
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值