definir sus propias <=>
, e incluyen comparable. Esto es de la Comparable doc:
class SizeMatters
include Comparable
attr :str
def <=>(anOther)
str.size <=> anOther.str.size
end
def initialize(str)
@str = str
end
def inspect
@str
end
end
s1 = SizeMatters.new("Z")
s2 = SizeMatters.new("YY")
s3 = SizeMatters.new("XXX")
s4 = SizeMatters.new("WWWW")
s5 = SizeMatters.new("VVVVV")
s1 < s2 #=> true
s4.between?(s1, s3) #=> false
s4.between?(s3, s5) #=> true
[ s3, s2, s5, s4, s1 ].sort #=> [Z, YY, XXX, WWWW, VVVVV]
En realidad no tiene que incluir comparable, pero se obtiene una funcionalidad adicional gratis si lo hace después de haber definido <=>
.
De lo contrario, puede usar Enumerable's sort
con un bloque si sus objetos ya implementan <=>
.
EDITAR: Otra forma de utilizar varias comparaciones diferentes es utilizar lambdas. Este sistema utiliza la nueva sintaxis de declaración 1.9.2:
ascending_sort = ->(a,b) { a <=> b }
descending_sort = ->(a,b) { b <=> a }
[1, 3, 2, 4].sort(& ascending_sort) # => [1, 2, 3, 4]
[1, 3, 2, 4].sort(& descending_sort) # => [4, 3, 2, 1]
foo = ascending_sort
[1, 3, 2, 4].sort(& foo) # => [1, 2, 3, 4]
Literalmente, se puede usar 'Items.Sort! {| x, y | x.my_comparator y} ', pero si este es el comportamiento de clasificación predeterminado para la clase, debería considerar algo así como lo que Tin Man tiene a continuación. – coreyward