问题引入
s1 = '$$$franklin$$$'
print(s1.strip('$')) # franklin
print(s1) # $$$franklin$$$
s2 = [1,2,3]
print(s2.extend([4,5,6])) # [1,2,3,4,5,6]
print(s2) # [1,2,3,4,5,6]
可以发现 字符串类型 在调用内置方法之后 并没有改变原字符串
然而 列表类型在调用内置方法之后 改变了原来的列表
问题分析
s1 = '$$$franklin$$$'
print(id(s1)) # 139891701591728
s1.strip('$')
print(id(s1)) # 139891698080560
# 内存地址并不一样
s2 = [1,2,3]
print(id(s2)) # 140219542798816
s2.extend([4,5,6])
print(id(s2)) # 140219542798816
# 内存地址相同
结论
对可变类型进行修改,并不会修改其内存地址,值会发生改变
对不可变类型进行修改,会重新申请一片内存空间,建立新的联系。
可变类型
"""
以列表为例,列表 l1 指向 其内存地址,在列表中存放 其实是每个索引 对应的 值的内存地址;
比如:值 1 的内存地址为 500,值 2 的内存地址为 530,列表 l1 的起始地址为 30.
那么在列表l1 的 0 号索引对应的存储空间内存储的就是 500;
1 号索引对应的存储空间内 存储的就是 530;
如果新增加一个值--新值 3 ,新值 3 的内存地址为 900;
则 2 号索引对应的存储空间内 存储的就是 900;
但是列表 l1 所指向的起始地址仍然是 30.
所以 对于可变类型来说 申请了一片存储空间之后 修改的只是内部的值 它的起始地址是不会改变的
"""
不可变类型
"""
对于不可变类型,例如:str = 666, 此时 str 对应的是666的内存地址
修改之后 str =111 ,此时 str 对应的是 111 的内存地址,str 与 666 的关系就断开了
所以,不可变类型的修改,其实是建立了与新的内存地址的联系
"""
常用数据类型分类
可变 | 列表、字典 |
---|---|
不可变 | 数字,字符串,元组 |