python基础(五)python中的可变数据类型和不可变数据存储原理

  python在内存中存储值时,它是根据数值的具体类型来选择不同的存储方式,在这一点上它是有别于编译语言的。不用声明变量数据类型的缺点就是你得了解python的内存管理机制。

(一)python中的不可变数据类型

  a.不可变数据类型有数值型、字符型、元组。
  b.存储原理:不允许变量的值发生变化,如果改变了变量的值,相当于是新建了一个对象新开辟一个内存区来存放该值;而对于相同值的对象,通过增加引用计数,来表示引用方式的增加而实际上在内存中则只有一个对象(一个地址),即这些引用都指向同一个地址。例如:
python基础(五)python中的可变数据类型和不可变数据存储原理_第1张图片

(二)python中的可变数据类型

  a.可变数据类型有列表,字典,集合。
  b.原理:允许变量的值发生变化,即如果对变量进行append、+=等这种操作后,它改变了变量的值,而不会新建一个对象,变量引用的对象的地址也不会变化(起始地址没变);相同值的可变数据类型,它们也是互相独立的对象,在不同的内存中,而不是像不可变数据类型那样只是增加了引用计数,它们是实实在在的独立对象。例如:
python基础(五)python中的可变数据类型和不可变数据存储原理_第2张图片

(三)关于列表乘法

  列表乘法中的元素在内存中是被作为不可变数据类型存储的,即只增加引用不增加内存,不创建独立对象。
python基础(五)python中的可变数据类型和不可变数据存储原理_第3张图片

你可能感兴趣的:(编程相关)