Why should order not matter? An array is an *ordered* list of elements as indexing by position indicates. a1[0] == a2[0] will return false, why then should a1 == a2 return true?
If you to ignore order you either have to compare sorted copies or resort to Set.
irb(main):008:0> puts "yo" if a1 == a2
=> nil
irb(main):009:0> puts "yo" if a1 != a2
yo
=> nil
I assumed order of elements would not be considered for equality. Is
there any particular reason for this behavior?
The reason for this behavior is that the creator of Ruby
and most of its users aren't devoid of knowledge of
programming. An array is not a set. An array is not a
hash (a.k.a. associative array). So of course order matters.
Does the order in which you read the chapters of a novel
matter? If order doesn't matter, then why is there a 'sort'
method that changes the order of an array?
The concept of order is an integral part of what it means to be an Array.
If you aren't interested in order, then a Set is probably a better
structure.
require 'set'
a = [1,2,3]
b = a.reverse
p a == b # false
p Set.new(a) == Set.new(b) # true
Gary Wright
···
On Jan 22, 2007, at 5:30 PM, Chris McMahon wrote:
I assumed order of elements would not be considered for equality. Is
there any particular reason for this behavior?