`
daiyuok
  • 浏览: 26664 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

python中可hash的对象

 
阅读更多

看核心编程时候有个叫hash的东西,呵呵,打开python文档看看:

 

hashable(可哈希性)

An object is hashable if it has a hash value which never changes during its lifetime (it needs a __hash__() method), and can be compared to other objects (it needs an __eq__() or __cmp__() method). Hashable objects which compare equal must have the same hash value.

(如果一个对象是可哈希的,那么在它的生存期内必须不可变(需要一个哈希函数),而且可以和其他对象比较(需要比较方法).比较值相同的对象一定有相同的哈希值)

 

翻译的比较生硬...简单的说就是生存期内可变的对象不可以哈希,就是说改变时候其id()是不变的.基本就是说列表,字典,集合了.

 

写一段代码验证一下:

a= [0,0,0]
b = {1:2,'c':9}
c = set(a)
string = 'hello'

class A():
    pass
a = A()
print hash(A)
print hash(a)
print hash(string)

print hash(c)
print hash(b)
print hash(a)

可以看出列表,字典,集合是无法哈希的,因为他们在改变值的同时却没有改变id,无法由地址定位值的唯一性,因而无法哈希.

分享到:
评论

相关推荐

    python批量hash256加密工具

    在"python批量hash256加密工具"中,可能包含的功能有: 1. 读取文本文件:工具可能会从一个或多个文本文件中读取内容,对每一行或整个文件进行哈希计算。 2. 批量处理:对于大量文本,工具可以实现并行处理,提高...

    深入源码解析Python中的对象与类型

    - `Py_ssize_t ob_size`: 表示变长对象中元素的数量,例如列表中元素的个数。 #### 方法和宏定义 为了方便地操作这些内部结构,Python提供了一系列宏定义: - `Py_REFCNT(ob)`: 用于获取对象`ob`的引用计数。 - `...

    python36的mmh3模块.rar

    3. 不可预测性:虽然不是加密哈希,但MurmurHash3的输出对输入的微小变化很敏感,这在很多应用中是有益的。 4. 可移植性:MurmurHash3有多个变种,适应不同的平台和数据宽度。 **四、应用场景** 1. 数据去重:...

    Python库 | murmurhash-1.0.0-cp27-cp27mu-manylinux1_x86_64.whl

    `murmurhash` 是一个广泛使用的非加密哈希函数库,其在Python中的实现为Python开发者提供了高效且高度可预测的哈希算法。这个特定的版本 "1.0.0" 是针对Python 2.7编译的,同时支持多平台架构,特别是64位的...

    利用Python如何生成hash值示例详解

    - `update()`: 可以重复利用同一个Hash对象,更新并加密更多的数据。 - `digest()`: 返回加密后的字节串。 - `hexdigest()`: 返回加密后的十六进制格式字符串。 - `copy()`: 克隆一个新的Hash对象,用于后续的加密...

    符合Python风格的对象1

    在不可变对象中,如 `Vector2d` 示例,`__hash__()` 通常基于对象的属性计算。 6. **`@property` 装饰器**: - `@property` 用于将方法转化为只读属性,这样可以防止外部直接修改对象的内部状态。在实现不可变对象...

    python hash每次调用结果不同的原因

    哈希值是通过哈希算法从任何对象中提取的一个整数。在Python中,字符串、数字、元组等类型都可以通过hash函数计算哈希值。理想情况下,同一对象的多次哈希调用应返回相同的哈希值。然而,在某些情况下,Python的hash...

    详解Python中的内建函数,可迭代对象,迭代器

    6. `sum(iterable[, start])`:对可迭代对象中的所有数值求和,`start`可指定初始值。 7. `sorted(iterable[, key][, reverse])`:返回排序后的列表,`key`可以指定排序规则,`reverse`指定升序或降序排列。 迭代器...

    python3-mmhash:MurmurHash2 的 Python3 端口

    Python3-mmhash库提供了一个简洁的接口,允许开发者在Python3环境中方便地使用MurmurHash2。其核心功能可能包括以下几个方面: 1. **API接口**:Python3-mmhash库通常会提供一个函数或类,如`mmh3`,用户可以通过...

    pythonturtle菜鸟教程-Python基础教程.pdf

    在Python脚本中,第一行通常会包含一个被称为“shebang”或“hash-bang”的注释,其形式为 `#!/usr/bin/python` 或 `#!/usr/bin/env python`。这个注释对于Linux和Unix系统非常重要,因为它告诉操作系统应该使用哪个...

    Python 的字典(Dict)是如何存储的

    - **键的哈希值**:Python字典中的键必须是不可变类型,比如字符串、数字或元组等。这是因为哈希函数需要根据键生成一个固定的散列值。如果键是可以改变的,那么每次修改键的值时,其散列值也会随之变化,这会导致...

    Python库 | x17_hash-1.6-cp35-cp35m-win32.whl

    标题中的“Python库 | x17_hash-1.6-cp35-cp35m-win32.whl”指的是一个Python的特定版本库——x17_hash,版本为1.6,它针对的是Python 3.5(cp35)架构,并且是为32位Windows系统(win32)设计的。这种格式的文件是...

    Python库 | mmh3-3.0.0-cp39-cp39-win32.whl

    - `mmh3.object_hash()`: 对Python对象(如字符串、整数、列表等)进行哈希,返回32位整数。 - `mmh3.array()`: 对数组或列表中的元素进行哈希,返回一个数组的哈希值,适合于处理批量数据。 - `mmh3.hash_bytes()`:...

    哈希算法在python中的调用代码实例

    然而,需要注意的是,`hash()`函数对于不可变对象(如字符串、元组)返回的哈希值是固定的,而对于可变对象(如列表、字典)的哈希值会根据对象内容的改变而变化。这是因为可变对象的哈希值是基于其内容计算的,而不...

    TDDOWNLOAD\Perl 与 Python 之间的一些异同

    Perl倡导的“多途径完成任务”与Python坚持的“最佳单一途径”哲学形成鲜明对比,这种差异也体现在两者的语法设计和社区文化中。 ### Perl与Python的基本数据类型对比 #### Perl - **标量(Scalar)**:用于存储...

    获取任意文件Hash值

    C#自己封装的获取任意文件Hash值DLL,添加引用,实例对象,传入文件path,返回hash值.

    python2.6库函数参考手册

    - **any()**: 测试可迭代对象中是否有任何元素为真。 - **ascii()**: 将对象转换为ASCII字符串。 - **bin()**: 将整数转换为二进制字符串。 - **bool()**: 转换值为布尔值。 - **bytearray()**: 创建一个可变的字节...

    浅谈python处理json和redis hash的坑

    如果需要保持JSON对象中键值对的顺序,可以使用OrderedDict来辅助json.loads()函数。这样做可以使得数据的顺序在处理过程中保持不变。 作者还提到了处理JSON数据时中文乱码的问题,并且指出在使用json.dumps()函数...

    python-data-structure-cn python数据结构中文版

    Python的`set`对象实现了集合数据结构,提供了高效的数据去重和集合运算。 这些数据结构在解决实际问题时有着广泛的应用,例如在算法设计、数据库索引、内存管理等领域。通过深入理解和熟练运用Python中的数据结构...

Global site tag (gtag.js) - Google Analytics