关于字典列表储存原理

names = ["a", "b", 'c', 'd']
data = {}
a = []
for i in names:
    data["name"] = i
    a.append(data)
print(a)
--------------------------
结果:
[{'name': 'd'}, {'name': 'd'}, {'name': 'd'}, {'name': 'd'}]

原理分析:
dict(字典)赋给list的是一个位置,对于这种代码,
data定义在循环外,每次使用a.append(data)赋给 list的都是相同的位置,而在同一位置的dict的值已经改变了,所以list取到的之前位置的值改变了,表现出后面数据覆盖前面数据的表象。
dict定义在循环内,相当于每一次循环生成一个data,占用不同的位置存储值,所以可以赋给list不同元素不同的位置,获得不同的值。

深层次解释:
Python中的对象之间赋值时是按引用传递的,如果需要拷贝对象,需要使用标准库中的copy模块。

  1. copy.copy 浅拷贝 只拷贝父对象,不会拷贝对象的内部的子对象。
  2. copy.deepcopy 深拷贝 拷贝对象及其子对象
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
字典是Python中非常重要的数据结构之一,它是一种可变的、无序的键值对集合。字典的底层实现原理是使用哈希表(Hash Table)。 哈希表是一种根据键(Key)直接访问值(Value)的数据结构。在字典中,每个键都会通过哈希函数转换为一个唯一的哈希值,然后根据哈希值将键值对存储在内存中的对应位置。当我们需要访问字典中的某个键对应的值时,系统会根据键的哈希值快速定位到对应的位置,从而实现高效的查找。 字典的底层实现原理使得它具有以下特点: - 快速查找:由于使用了哈希表,字典可以在常数时间内(O(1))查找某个键对应的值,即使字典中的键值对数量很大。 - 灵活性:字典中的键可以是任意不可变的数据类型,如整数、浮点数、字符串等,而值可以是任意类型的对象。 - 动态性:字典是可变的,可以随时添加、删除或修改键值对。 下面是一个简单的示例演示了字典的底层原理: ```python # 创建一个字典 my_dict = {'name': 'Alice', 'age': 25, 'city': 'New York'} # 访问字典中的值 print(my_dict['name']) # 输出:Alice # 添加新的键值对 my_dict['gender'] = 'female' # 修改键对应的值 my_dict['age'] = 26 # 删除键值对 del my_dict['city'] # 遍历字典 for key, value in my_dict.items(): print(key, value) ``` 这是一个简单的示例,展示了字典的一些基本操作。实际上,字典的底层实现原理还涉及到哈希冲突的处理、动态扩容等细节,但这超出了本回答的范围。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值