Towards understanding dictionaries

前端 未结 2 505
一向
一向 2021-01-21 04:22

I am required to use multiple hashtables, so in c++, I would normally use an std::unordered_map. So far I can understand that I can use a dictionary in Python, so let\'s assume

相关标签:
2条回答
  • 2021-01-21 04:44

    A simple Python shell experiment to show that different dictionaries can use the same key:

    >>> my_dict_1 = {'foo':1}
    >>> my_dict_2 = {'foo':2}
    >>> my_dict_1,my_dict_2
    ({'foo': 1}, {'foo': 2})
    

    This is a good discussion of how it is implemented. The key point is that each dictionary is allocated its own portion of memory (which can of course grow as needed). The exact same hash function is used for both dictionaries, but is being used to probe different areas in memory.

    0 讨论(0)
  • 2021-01-21 04:48

    id(...)

    id(object) -> integer

    Return the identity of an object. This is guaranteed to be unique among simultaneously existing objects. (Hint: it's the object's memory address.)

    Above is the id doc string, it says that object's identity is object's memory address, so we can use the id function to see the variable's memory address:

    In your program, I can see the address like this:

    def main():
        my_dict_1 = {}
        my_dict_1['foo'] = 1
        my_dict_2 = {}
        my_dict_2['foo'] = 2
        print(hex(id(my_dict_1['foo'])))
        print(hex(id(my_dict_2['foo'])))
    
    if __name__ == '__main__':
        main()
    

    This program output this:

    0x9a33e0
    0x9a3400
    

    We can see that my_dict_1['foo'] and my_dict_2['foo'] have different memory address.

    So I think the two dicts should use the same hash function, but the variable's memory address should be the sum of the hash value and a base value. In this way, the two variable will be stored in the different memory areas.

    0 讨论(0)
提交回复
热议问题