可变对象 list dict set
不可变对象 数值型(int float) 字符串类型 tuple
对于不可变对象 int float string 来说,类似于c中的字符串常量(const char *) a=5,b=5 id(a)与id(b)是一样的,即a和b指向同一块内存区域 对于string来说也是这样的。当a=6的时候,此时a指向的是另一块区域了。所以说对象是不可改变的。Python有垃圾回收机制,当b=7的时候,此时保存5的内存区域不在被使用,那么就会被回收掉了
对了tuple来说是不一样的,t1=(1,2,3) t2=(1,2,3) t1和t2的内存区域不一样。元组中的元素是可以理解成c++中的顶层const指针类型,t1[0]指向的内存区域是不能变的,t1[0]=3,因为数值类型也是不能改变的,所以此时t1[0]要指向新的内存,但是因为是顶层const 指针类型,不能改变指向的区域,所以,这样赋值是有问题的。但是如果tuple中的元素有list或者dic可变类型,例如 t1=(1,2,[2,3]) t1[2]=[3,4],这样赋值是不可以的,原因同上,但是t1[2][1]=4,这样是允许的。
对于函数的传参来说,Python的传参,传的是引用类型。也就是指针,对于不可变对象,不会对调用函数中的数据造成影响(因为传的是1级指针),对于可变对象来说,因为可变对象是List和dic,均为复合类型,所以会对调用函数中的数据造成影响
对于python内置类型的+= 以及=+的操作,这两个得出的结果是不一致的(对于不可变类型的是一样的,可变的是不一样的)
a=[5] b=a a+=[5] 这样操作后,b的值也会改变,+=首先会在类中寻找_iadd_的函数,如果没有在想办法调用_add_的函数,_iadd_函数是会在原来的内存上直接进行操作,而_add_是不会再原来的内存上进行操作,而是会返回一个新的内存块区域。赋给左边的变量。所以a=a+[5],a会指向一个新内存区域,并不会影响原来的内存。这是对于可变的变量来说的,对于内存不可变的变量,是没有_iadd_的函数,因为不会对原内存进行改变的。