TreeMap 的应用

1. 应用场景。
对于一对多的映射
A --B
--C
--D
--E

当取得A时,即使BCDE也是有顺序的。
但是如果对于C,需要根据另一个配置表F进行再次装配,并且需要按照F的某一个字段进行排序,这种情况下可以利用TreeMap 实现。

2. 实现概述。

由于框架限制,一些其他方法不可行。
所以实现如下:

SortedMap sortedMap=new TreeMap();
A a=DAO.find();
List<C> cl= a.getC();
List<C> newCl = new List();
for(Iterator it = cl.iterator()){
C c = it.next;
F f = DAO.find(c.关联字段);
c.setXX(f.getXX);
c.setYY(f.getYY);
[color=red] //放入有序MAP中
sortedMap.put(f.排序字段, c);[/color]
}

[color=red]//由MAP转换为C List[/color]
Set set=sortedMap.entrySet();
for (Iterator it = set.iterator(); it.hasNext();){
C c = it.next().getValue();
newCl .add(c);
}
[color=red]//设定排序后的C List
a.setC(newCl );[/color]

2.

// [color=darkred]Using a TreeMap for alphabetical ordering of attribute names[/color]
Map<String, Object> attributesToExpose = new TreeMap<String, Object>();


Map<String, Object> params = new TreeMap<String, Object>();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值