您应该能够以相反的顺序迭代所需的排序:
list = [[2, 0, 1], [1, 5, 2], [1, 0, 3]]
list = list.sort{ a,b -> a[2] <=> b[2] }
list = list.sort{ a,b -> a[1] <=> b[1] }
list = list.sort{ a,b -> a[0] <=> b[0] }
assert list == [[1, 0, 3], [1, 5, 2], [2, 0, 1]]
每个都应该覆盖前一个,足以保持组合排序的完整性。
您还可以将它们按顺序链接起来埃尔维斯操作员,?: http://groovy.codehaus.org/Operators#Operators-ElvisOperator(?:),当前一个比较相等时,它将推迟到下一个比较(并且<=>
回报0
):
list.sort { a,b -> a[0] <=> b[0] ?: a[1] <=> b[1] ?: a[2] <=> b[2] }