Skip to content Skip to sidebar Skip to footer

How Is Hash(none) Calculated?

On my machine, hash(None) returns a value: >>> hash(None) -2138947203 Just out of curiosity, how is this hash value calculated? It doesn't seem as though this value is b

Solution 1:

It is based on None's id, but None is one of a few Python objects that are defined as C global variables, so its address (typically) doesn't change between Python runs. Other such objects are True and False (but these are hashed as ints), or built-in classes like object and tuple.

The address (and hash) is different between different CPython builds, however. On my system, hash(None) gives 539708.

Solution 2:

Solution 3:

As None is an object, I've wrote a function object_hash for calculation of object hash:

import sys
import struct

defint_overflow(value):
    """ simulate integer overflow """
    m = sys.maxint + 1return (value + m) % (m * 2) - m

defobject_hash(value):
    res = id(value)
    sizeof_void_p = struct.calcsize('P')
    res = int_overflow((res >> 4) | (res << (8 * sizeof_void_p - 4)))
    if res == -1:
        res = -2return res

The resulting hashes are equal:

>>>hash(None)
492116
>>>object_hash(None)
492116L

Post a Comment for "How Is Hash(none) Calculated?"