pythonset类型底层实现_深入理解Python的set和dict

dict常用操作

引言

clear(): 清空字典

copy(): 返回一个浅拷贝

fromkeys(): 将可迭代对象中的每一个元素作为key和同一个value拼成字典

get(): 根据key返回value,若无对应的键值对,则返回None,也可以指定默认返回值,和索引访问相比,不会产生异常。

items():返回一个dict_items类型,支持迭代,键值对以元组形式组织

setdefault(): 获取key对应的value值,先调用get(),若不存在该键值对,则添加

update(): 合并字典,或键值对元组构成的可迭代对象

使用案例# 1. clear()

d = {name:"MetaTian", age:"22"}

d.clear()

# 2. copy()

new_dict = d.copy()

new_dict["age"] = 18

print(new_dict)

print(d)

# resutl:

# {'age': 18, 'name': 'MetaTian'}

# {'age': '22', 'name': 'MetaTian'}

# 3. fromkeys()

d = dict.fromkeys(range(3), "MetaTian")

print(d)

# result:

# {0: 'MetaTian', 1: 'MetaTian', 2: 'MetaTian'}

# 4. get()

print(d.get(2))

print(d.get(3))

print(d.get(3, "null"))

# result:

# MetaTian

# None

# null

# 5. items()

print(type(d.items()))

print(d.items())

# result:

# dict_items([(0, 'MetaTian'), (1, 'MetaTian'), (2, 'MetaTian')])

# 6. setdefault()

d = {}

value = d.setdefault("name", "MetaTian")  # 如果无 name 这个 key,则添加

print(value, d)

# result:

# MetaTian {'name': 'MetaTian'}

# 7. update()

d1 = {1:"a"}

d2 = {2:"b"}

d1.update(d2)

d2.update([(3, "c"), (4, "d")])

print(d1)

print(d2)

# result:

# {1: 'a', 2: 'b'}

# {2: 'b', 3: 'c', 4: 'd'}

set和frozenset

引言

set是可变集合,frozenset是不可变集合

集合中的元素无序,不重复

使用案例"""

通过 set(Iterable) 来构建出可变集合对象

通过 frozenset(Iterable) 构建不可变集合对象

"""

s = set("12345666")

fs = frozenset(['a', 'b', 'c', 'a'])    # 不可变类型,可以作为 dict 的 key

print(s)

print(fs)

# result:

# {'6', '1', '4', '5', '3', '2'}

# frozenset({'b', 'a', 'c'})

"""

向 set 中添加元素

add()

update()

"""

s1, s2 = set("123"), set("234")

s1.update(s2)

s2.add('5')

print(s1)

print(s2)

# result:

# {'1', '2', '3', '4'}

# {'2', '3', '5', '4'}

"""

集合的运算

- 差

& 交

| 并

"""

s1, s2 = set("123"), set("234")

print(s1 - s2)

print(s1 & s2)

print(s1 | s2)

# result:

# {'1'}

# {'2', '3'}

# {'3', '1', '2', '4'}

dict和set的实现原理

引言

dict和set的查找性能远远大于list

dict和set底层通过散列表存储,因此也要求dict的key是可哈希的,不可变对象都是可哈希的

哈希的原理.

以字典为例.

存储之前要通过哈希函数来计算key的值,得到存储索引,如果得到的结果已经被使用,要处理冲突,重新计算后再进行存储

自定义的类通过实现__hash__(),就可以存储在dict和set中.

因此,具体的存储顺序和元素添加的顺序可能有关.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值