网站首页 > 技术文章 正文
对象作为集合(set)元素或字典(dictionary)的键时,需要特别注意对象的可哈希性(hashability)。在Python中,只有不可变(immutable)对象才能被用作集合的元素或字典的键。这是因为集合和字典的内部实现依赖于哈希表,而哈希表要求元素或键必须是唯一的,且其哈希值在对象的生命周期内不可变。
可哈希性(Hashability)
可哈希对象:不可变类型,如整数(int)、浮点数(float,虽然其精度限制可能导致哈希冲突,但在实践中被视为可哈希)、字符串(str)、元组(tuple,但仅当元组内的所有元素都是可哈希的时)等,都可以作为字典的键或集合的元素。
不可哈希对象:可变类型,如列表(list)、字典(dict)、集合(set)等,不能作为字典的键或集合的元素,因为它们的内容可以更改,这会导致哈希值的不稳定。
示例
对象作为字典的键
python
# 使用字符串作为键
my_dict = {'name': 'Luo Tianyi', 'age': 16}
# 使用元组(包含不可变类型)作为键
my_dict[(1, 2, 3)] = 'tuple key'
# 尝试使用列表作为键(这会抛出TypeError)
# my_dict[[1, 2, 3]] = 'list key' # TypeError: unhashable type: 'list'
# 使用自定义的不可变对象作为键(需要实现__hash__和__eq__方法)
class Point:
def __init__(self, x, y):
self.x = x
self.y = y
def __hash__(self):
return hash((self.x, self.y))
def __eq__(self, other):
if isinstance(other, Point):
return self.x == other.x and self.y == other.y
return False
p1 = Point(1, 2)
my_dict[p1] = 'Point key'
print(my_dict[p1]) # 输出: Point key
对象作为集合的元素
python
# 使用不可变对象(如字符串和元组)作为集合的元素
my_set = {'apple', (1, 2, 3)}
# 尝试使用列表作为集合的元素(这会抛出TypeError)
# my_set.add([1, 2, 3]) # TypeError: unhashable type: 'list'
# 使用自定义的不可变对象(如上例中的Point类)作为集合的元素
my_set.add(Point(2, 3))
print(my_set) # 输出可能包括: {'apple', (1, 2, 3), <__main__.Point object at 0x...>}
在将对象用作字典键或集合元素时,确保对象是不可变的,或者如果对象是自定义的,请确保正确实现了__hash__和__eq__方法。
- 上一篇: Python合并2个字典成1个新字典的9种方法
- 下一篇: Python元组与字典用法详解
猜你喜欢
- 2024-12-07 C# “字典” Dictionary 的简单用法:轻松管理键值对
- 2024-12-07 以专业方式在 Python 中进行调试:将 print() 替换为 ic()
- 2024-12-07 python基础——字典详解
- 2024-12-07 Python教程-字典
- 2024-12-07 「教程10」国产编程语言Cbrother 字典
- 2024-12-07 Python数据类型——字典
- 2024-12-07 Python字典和集合
- 2024-12-07 128.C# Dictionary字典
- 2024-12-07 pthon每天学习一点点(字典推导式)
- 2024-12-07 Python字典:定义、基本操作与方法详解
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)