本文共 1065 字,大约阅读时间需要 3 分钟。
在Python中,对象哈希机制是理解对象存储和比较的关键知识点。本文将从根本到表面,详细解析Python中的哈希机制及其应用。
在Python中,当你使用 hash() 函数来获取一个对象的哈希值时,会调用该对象的 __hash__ 方法。这个方法的返回值决定了对象的哈希值,最终决定了对象的存储位置和比较结果。需要注意的是,__hash__ 方法只能返回整数值,否则会抛出 TypeError 错误。
class Str: def __hash__(self): return 12345p = Str()print(hash(p)) # 输出:12345
此外,字符串、数字、元组等不可变类型都具备可哈希性,而列表、字典等可变类型则不具备可哈希性。
在Python中,类型的哈希性决定了对象是否可以用于作为字典的键或集合的成员。
不可变类型通常可以被哈希化,例如:
print(hash(132)) # 输出:132print(hash(1.1)) # 输出:230584300921369601print(hash((4,5))) # 输出:3713084879518070856print(hash([11,23,4,4])) # 输出:报错print(hash({"age":12})) # 输出:报错 从上述代码可以看出,字符串、数字和元组可以被哈希化,而列表和字典则不行。
可变类型通常不具备可哈希性,因为它们的状态可能随时间改变。
如果你需要让一个对象变得可哈希,可以通过重写 __hash__ 方法来实现。
class Foo: def __init__(self): self.name = "皮皮" self.l = [1,2,3,] def __hash__(self): return hash(self.name)f = Foo()print(hash(f)) # 输出:-3176404254760418957
通过以上方法,我们可以为自定义对象定义哈希值,从而实现其可哈希化。希望以上内容能帮助你更好地理解Python中的哈希机制。
转载地址:http://ymto.baihongyu.com/