python在内存中存储值时,它是根据数值的具体类型来选择不同的存储方式,在这一点上它是有别于编译语言的。不用声明变量数据类型的缺点就是你得了解python的内存管理机制。
(一)python中的不可变数据类型
a.不可变数据类型有数值型、字符型、元组。
b.存储原理:不允许变量的值发生变化,如果改变了变量的值,相当于是新建了一个对象新开辟一个内存区来存放该值;而对于相同值的对象,通过增加引用计数,来表示引用方式的增加而实际上在内存中则只有一个对象(一个地址),即这些引用都指向同一个地址。例如:
(二)python中的可变数据类型
a.可变数据类型有列表,字典,集合。
b.原理:允许变量的值发生变化,即如果对变量进行append、+=等这种操作后,它改变了变量的值,而不会新建一个对象,变量引用的对象的地址也不会变化(起始地址没变);相同值的可变数据类型,它们也是互相独立的对象,在不同的内存中,而不是像不可变数据类型那样只是增加了引用计数,它们是实实在在的独立对象。例如:
(三)关于列表乘法
列表乘法中的元素在内存中是被作为不可变数据类型存储的,即只增加引用不增加内存,不创建独立对象。