How are hash collisions handled?

前端 未结 3 841
野的像风
野的像风 2021-01-18 08:03

I\'ve recently learned a little bit about hash values, and therefore also heard of about the problem of hash collisions.
I therefore wondered: How does one deal with tho

相关标签:
3条回答
  • 2021-01-18 08:12

    Swift dictionaries uses open addressing and linear probing.

    Here is a link to the actual source documentation explaining everything: https://github.com/apple/swift/blob/master/stdlib/public/core/HashedCollections.swift.gyb

    0 讨论(0)
  • 2021-01-18 08:31

    Fundamentally, there are two major ways of handling hash collisions - separate chaining, when items with colliding hash codes are stored in a separate data structure, and open addressing, when colliding data is stored in another available bucket that was selected using some algorithm.

    Both strategies have numerous sub-strategies, described in Wikipedia. The exact strategy used by a particular implementation is, not surprisingly, implementation-specific, so the authors can change it at any time for something more efficient without breaking the assumptions of their users.

    A this point, the only way to find out how Swift handles collisions would be disassembling the library (that is, unless you work for Apple, and have access to the source code). Curious people did that to NSDictionary, and determined that it uses linear probing, the simplest variation of the open addressing technique.

    0 讨论(0)
  • 2021-01-18 08:36

    There are two basic techniques:

    1. Rehash using a different prime, typically N- 2 where N is the original prime, chosen such that both N and N-2 are prime.
    2. Use a list per hash.

    Or both.

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