List 排序

List 排序,第1张

概述数组还有一个重要内容就是要排序,排序是任何集合 *** 作所躲不过去的。在Java语言中,在Collections接口中提供了“sort”方法来用于对List对象进行排序,可能我们在Java语言编程中已经用过无数次了,在这里限于篇幅就不多说了。 在Groovy语言中,同样提供了“sort”方法,而且比Java语言的“sort”方法使用起来更加的方便。这就是我们这一个《魔幻数组》系列所要谈到的。 先来看一个

数组还有一个重要内容就是要排序,排序是任何集合 *** 作所躲不过去的。在Java语言中,在Collections接口中提供了“sort”方法来用于对List对象进行排序,可能我们在Java语言编程中已经用过无数次了,在这里限于篇幅就不多说了。

Groovy语言中,同样提供了“sort”方法,而且比Java语言的“sort”方法使用起来更加的方便。这就是我们这一个《魔幻数组》系列所要谈到的。

先来看一个简单的例子:

     

      def List1 = [1,5,7,3,9,4]

     

      println List1.sort()

 

 

结果为:

[1,3,4,5,7,9]

可以看到,Groovy语言的“sort”方法比Java语言的“sort”方法更加简单。上面的例子是对数字的排序,同样,如果数组元素是字符串的话,同样也可以使用“sort”方法来排序。请看下面的例子:

 

      def List2 = ['a','h',204); Font-family: 'CourIEr New';" lang="EN-US">'c',204); Font-family: 'CourIEr New';" lang="EN-US">'i']

 

  println List2.sort()

 

 

结果为:

["a","c","h","i"]

 

看过了上面的例子,我们说,是的,我们使用“sort”方法对数组进行排序相当简单。但我们有更高的要求:我们想对List1对象按倒序排序,该怎么办呢?

     

      List1.sort{

         a,b ->

           b <=> a

      }

   

      println List1

 

 

 

可以看到,要进行倒序排序很简单,只要在两个元素进行比较的时候将ab改为ba就可以了。

上面的结果为:

[9,1]

 

当然了,对于数组的排序,我们还有一个基本的要求是能够对数组元素为GroovyBean对象进行排序。比如我们有如下的一个GroovyBean类:

 

class Empl

{

    String ID

    String name

}

 

 

然后,我们有了如下的数组:

 

      def List3 = [new Empl(ID:5,name:'Tom'),new Empl(ID:8,204); Font-family: 'CourIEr New';" lang="EN-US">'Wallace'),

                   new Empl(ID:4,204); Font-family: 'CourIEr New';" lang="EN-US">'Mike'),153); Font-family: 'CourIEr New';" lang="EN-US">new Empl(ID:6,204); Font-family: 'CourIEr New';" lang="EN-US">'Jack')]

 

 

现在,我们要对List3的元素按ID的顺序排序。该怎么办呢?

 

      List3.sort{

           a,b ->

              a.ID <=> b.ID

       }

 

   

 

很简单,我们还是使用闭包来对数组元素的排序方法进行定义。下面来测试上面的代码是否按我们的要求来排序了:

 

       List3.each{

           println "${it.ID} ${it.name}"

    }

 

结果为:

4 Mike

5 Tom

6 Jack

8 Wallace

 

有些特殊的时候,我们希望对某一个已经排序好了的数组进行随机排序,那又该怎么办呢?

比如我们有如下的一个数组:

      

       def List4 = [1,2,4,6]

      

我们希望对List4的排序顺序打乱,而且要是随机的。

      

       List4.sort{

           Math.random()

       }

      

    println List4

 

结果为:

[3,1,2,6]

 

当然,既然是随机的,当你第二次运行上面的代码的时候,会得到不同的结果,如下所示:

[3,6,5] 总结

以上是内存溢出为你收集整理的List 排序全部内容,希望文章能够帮你解决List 排序所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1268063.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存