PyHash API

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

typePy_hash_t

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

在 3.2 版被加入.

typePy_uhash_t

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

在 3.2 版被加入.

PyHASH_MODULUS

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

在 3.13 版被加入.

PyHASH_BITS

PyHASH_MODULUSP 的指數n

在 3.13 版被加入.

PyHASH_MULTIPLIER

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

在 3.13 版被加入.

PyHASH_INF

正無窮大回傳的雜湊值。

在 3.13 版被加入.

PyHASH_IMAG

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

在 3.13 版被加入.

typePyHash_FuncDef

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

Py_hash_t(*consthash)(constvoid*,Py_ssize_t)

雜湊函式。

constchar*name

雜湊函式名稱(UTF-8 編碼字串)。

constinthash_bits

雜湊值的內部大小(以位元為單位)。

constintseed_bits

Seed 輸入的大小(以位元為單位)。

在 3.4 版被加入.

PyHash_FuncDef*PyHash_GetFuncDef(void)

取得雜湊函式定義。

也參考

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

在 3.4 版被加入.

Py_hash_tPy_HashPointer(constvoid*ptr)

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

此函式不會失敗:它不會回傳-1

在 3.13 版被加入.

Py_hash_tPy_HashBuffer(constvoid*ptr,Py_ssize_tlen)

Compute and return the hash value of a buffer oflen bytesstarting at addressptr. The hash is guaranteed to match that ofbytes,memoryview, and other built-in objectsthat implement thebuffer protocol.

Use this function to implement hashing for immutable objects whosetp_richcompare function compares to anotherobject's buffer.

len 必須大於或等於0

此函式總是會成功執行。

在 3.14 版被加入.

Py_hash_tPyObject_GenericHash(PyObject*obj)

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

在 CPython 中,它等價於Py_HashPointer()

在 3.13 版被加入.