[Python-Dev] getting rid of default object.__hash__ (SF 660098)
Samuele Pedroni
pedronis at bluewin.ch
Mon Dec 22 16:43:40 EST 2003
At 13:32 22.12.2003 -0800, Guido van Rossum wrote:
> > >Since the default hash simply takes id() of the object, it's easy to
> > >fix such code once the failure is understood though.
> >
> > Jython 2.2a0 on java1.4.0_02 (JIT: null)
> > Type "copyright", "credits" or "license" for more information.
> > >>> class C: pass
> > ...
> > >>> id(C)
> > 1
> > >>> hash(C)
> > 9174506
> > >>>
> >
> > I see, but then there should be probably be a different way to spell
> > the default hash, because id is not a sensible option for Jython etc
>
>Ow, you're right. I bet this is why object.__hash__ was introduced in
>the first place.
>
>We're either back to square one, or we can add a __default_hash__ to
>object which has the default hash implementation -- this isn't very
>pretty but at least it works.
yes, or hash should grow a keyword argument to get access to the default
impl, which would be id for CPython but not for all Python impls in
general. The problem is that in general it cannot be expected from Python
implementations to implement the default hash in terms of id because the
latter can be much more costly beacuse of its uniqueness constraints.
regards.
More information about the Python-Dev
mailing list