列表、字典的复制

定义一个列表/字典,当复制这个列表/字典并定义一个新的列表/字典时,通过修改之前的列表/字典来了解这个问题

count = {
    "name":"hh",
    "conut": 1234,
    "info": [100,10]
}

count2 = count.copy()   # 复制count内存中的地址
count2["name"] = "zz"
count['info'][1] += 30  # 修改info的值 后钻count 和count2 中都有变化

print(count,count2)   # 类似主卡和副卡的概念

在上面的程序中定义一个字典count,count2复制了count,此时打印count和count2 ,显示的内容是一样的。

{'name': 'hh', 'conut': 1234, 'info': [100, 10]} 
{'name': 'hh', 'conut': 1234, 'info': [100, 10]}

现在修改count的“name”

>>>count["name"] = "aa"  # 修改count的“name”的值为"aa"
{'name': 'aa', 'conut': 1234, 'info': [100, 10]}  # count中
{'name': 'hh', 'conut': 1234, 'info': [100, 10]} # count2中

通过修改count的“name”的值后发现,此时,字典count变化了但是count2的没有变化

现在修改info中的内容

两个字典的内容都是变化的

这个变化是发生在内存中的,新建一个字典的时,内存会分配一块内存空间给count,这个内存存放的是字典内容的地址,count2复制的仅仅是count1的内存地址。

当字典count中增加新的内容的时,这个内容会分配一块新的内存,并指向新的内容,而原来的name指向的“hh”还指向了count2,所以“hh”不会被回收。

当修改count的列表的时候,是修改的列表的内容,而列表的地址没有被修改,所以count和count2中变化是一样的。

posted @   hzxPeter  阅读(238)  评论(0编辑  收藏  举报
编辑推荐:
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
阅读排行:
· 后端思维之高并发处理方案
· 千万级大表的优化技巧
· 在 VS Code 中,一键安装 MCP Server!
· 想让你多爱自己一些的开源计时器
· 10年+ .NET Coder 心语 ── 继承的思维:从思维模式到架构设计的深度解析
点击右上角即可分享
微信分享提示