PyHash API
**********

另請參閱 "PyTypeObject.tp_hash" 成員和 數值型別的雜湊。

type Py_hash_t

   雜湊值型別：有符號整數。

   在 3.2 版被加入.

type Py_uhash_t

   雜湊值型別：無符號整數。

   在 3.2 版被加入.

Py_HASH_ALGORITHM

   A numerical value indicating the algorithm for hashing of "str",
   "bytes", and "memoryview".

   The algorithm name is exposed by "sys.hash_info.algorithm".

   在 3.4 版被加入.

Py_HASH_FNV
Py_HASH_SIPHASH24
Py_HASH_SIPHASH13

   Numerical values to compare to "Py_HASH_ALGORITHM" to determine
   which algorithm is used for hashing. The hash algorithm can be
   configured via the configure "--with-hash-algorithm" option.

   在 3.4 版被加入: Add "Py_HASH_FNV" and "Py_HASH_SIPHASH24".

   在 3.11 版被加入: Add "Py_HASH_SIPHASH13".

Py_HASH_CUTOFF

   Buffers of length in range "[1, Py_HASH_CUTOFF)" are hashed using
   DJBX33A instead of the algorithm described by "Py_HASH_ALGORITHM".

   * A "Py_HASH_CUTOFF" of 0 disables the optimization.

   * "Py_HASH_CUTOFF" must be non-negative and less or equal than 7.

   32-bit platforms should use a cutoff smaller than 64-bit platforms
   because it is easier to create colliding strings. A cutoff of 7 on
   64-bit platforms and 5 on 32-bit platforms should provide a decent
   safety margin.

   This corresponds to the "sys.hash_info.cutoff" constant.

   在 3.4 版被加入.

PyHASH_MODULUS

   用於數值雜湊方案的梅森質數 (Mersenne prime) "P = 2**n -1"。

   This corresponds to the "sys.hash_info.modulus" constant.

   在 3.13 版被加入.

PyHASH_BITS

   "PyHASH_MODULUS" 中 "P" 的指數 "n"。

   在 3.13 版被加入.

PyHASH_MULTIPLIER

   用於字串和其他各種雜湊的質數乘數 (prime multiplier)。

   在 3.13 版被加入.

PyHASH_INF

   正無窮大回傳的雜湊值。

   This corresponds to the "sys.hash_info.inf" constant.

   在 3.13 版被加入.

PyHASH_IMAG

   用於複數虛數部分的乘數。

   This corresponds to the "sys.hash_info.imag" constant.

   在 3.13 版被加入.

type PyHash_FuncDef

   "PyHash_GetFuncDef()" 所使用的雜湊函式定義。

   Py_hash_t (*const hash)(const void*, Py_ssize_t)

      雜湊函式。

   const char *name

      雜湊函式名稱（UTF-8 編碼字串）。

      This corresponds to the "sys.hash_info.algorithm" constant.

   const int hash_bits

      雜湊值的內部大小（以位元為單位）。

      This corresponds to the "sys.hash_info.hash_bits" constant.

   const int seed_bits

      Seed 輸入的大小（以位元為單位）。

      This corresponds to the "sys.hash_info.seed_bits" constant.

   在 3.4 版被加入.

PyHash_FuncDef *PyHash_GetFuncDef(void)

   取得雜湊函式定義。

   也參考:

     **PEP 456**「安全且可交替使用的雜湊演算法 (Secure and
     interchangeable hash algorithm)」。

   在 3.4 版被加入.

Py_hash_t Py_HashPointer(const void *ptr)

   雜湊指標值：將指標值作為整數處理（在內部轉型為 "uintptr_t"）。指標
   不會被取值 (dereference)。

   此函式不會失敗：它不會回傳 "-1"。

   在 3.13 版被加入.

Py_hash_t PyObject_GenericHash(PyObject *obj)

   泛用雜湊函式，旨在放入型別物件的 "tp_hash" 插槽中。其結果僅取決於物
   件的識別性。

   在 CPython 中，它等價於 "Py_HashPointer()"。

   在 3.13 版被加入.
