In the Java world when one overrides "equals" in a class it is also
necessary to override "hashCode" so that objects behave properly in
collections. Does the same apply in the Ruby world, ie, it is
necessary to override "hash" when overriding "=="?
Are there helper idioms or libraries in Ruby to assist in constructing
"==" and "hash" methods (comparable to Java's Jakarta commons
HashCodeBuilder and EqualsBuilder)?
In the Java world when one overrides "equals" in a class it is also
necessary to override "hashCode" so that objects behave properly in
collections. Does the same apply in the Ruby world, ie, it is
necessary to override "hash" when overriding "=="?
You'll need to define #hash and #eql? as well.
Are there helper idioms or libraries in Ruby to assist in constructing
"==" and "hash" methods (comparable to Java's Jakarta commons
HashCodeBuilder and EqualsBuilder)?
If its a wrapper object, I usually pass through to the wrapper. If its a composite object something like ^ ing all the components hashes together works.
Its not hard enough that you need an extra library.
You'll want to define #<=> and include Comparable if you want to sort your objects sensibly.
#eql? is only used by Hash to determine if two keys (#hash) collide. Usually it just calls #==.
if object1.hash == object2.hash and object1.eql? object2 then
# both objects occupy the same slot in a Hash
else
# the objects occupy different slots in a Hash
end
···
On 15 Sep 2005, at 07:50, Brian Buckley wrote:
What is the difference between "eql?" and "==" in Ruby?