I have a class (let's call it myClass
) that implements both __hash__
and __eq__
. I also have a dict
that maps myClass
objects to some value, computing which takes some time.
Over the course of my program, many (in the order of millions) myClass
objects are instantiated. This is why I use the dict
to keep track of those values.
However, sometimes a new myClass
object might be equivalent to an older one (as defined by the __eq__
method). So rather than compute the value for that object again, I'd rather just lookup the value of older myClass
object in the dict
. To accomplish this, I do if myNewMyClassObj in dict
.
Here's my question:
When I use that in
clause, what gets called, __hash__
or __eq__
? The point of using a dict
is that it's O(1) lookup time. So then __hash__
must be called. But what if __hash__
and __eq__
aren't equivalent methods? In that case, will I get a false positive for if myNewMyClassObj in dict
?
Follow up question:
I want to minimize the number of entries in my dict
, so I would ideally like to keep only one of a set of equivalent myClass
objects in the dict
. So again, it seems that __eq__
needs to be called when computing if myNewClassObj in dict
, which would defile a dict
's O(1) lookup time to an O(n) lookup time