当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:13:00  来源:本站整理

容器的排序[Java编程]

赞助商链接



  本文“容器的排序[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

从资料库的概念来看,Set、Map、Bag是无序的,而List是有序的,这边所谓的无序或有序,是指将容器中物件储存至资料库时,能否依容器物件中的次序来储存.

但是从资料库获得资料之後,您大概会但愿Set、Map等容器中的物件可以依一定的次序来布列,您可以从两个层次来容器中的物件排序,一是在载入资料後於JVM中排序,另一是在资料库中直接利用order by子句来排序.

以 Set 这篇文章中的典范来作阐明,要在JVM中就资料举行排序,您可以在映射文件中利用sort属性来定义容器的排序,这实用於Set与Map,比方:

User.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping
   PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
   "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>

   <class name="onlyfun.caterpillar.User" table="user">
     ....
     <set name="emails" table="email" sort="natural">
       <key column="id"/>
       <element type="java.lang.String"
           column="address"/>
     </set>
   </class>

</hibernate-mapping>

sort="natural"表示利用物件的comparaTo()办法来举行排序,容器中的物件上必须有实作java.lang.Comparable 介面,比方String就有实作java.lang.Comparable介面,后果会利用字典次序来布列容器中的物件.

您可以实现自己的排序方法,只要定义一个类别来实作java.util.Comparator介面,比方:

CustomComparator.java
package onlyfun.caterpillar;

import java.util.Comparator;

public class CustomComparator implements Comparator {
   public int compare(Object o1, Object o2) {
     if (((String) o1).equals(o2))
       return 0;
     return ((Comparable) o1).compareTo(o2) * -1;
   }
}


  以上是“容器的排序[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • 容器的排序
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .