内存分为两部分,一部分叫栈区,一部分叫堆区,栈区是用来存放变量名称的,堆区是用来存放变量的值的。
1、is和==的区别
is是表示内存位置一样,即变量的id是一样的才会返回true,而==则表示两个变量的值是否相等,只有值相等的时候才会返回true
2、直接引用和间接引用
name = '张三' #直接引用
l1 = ['a','b',name] #此处的name就是间接引用
3、列表在内存中的存储
列表不会存储真正的值,只会存放索引和值的内存地址,值会存放在一个独立的内存空间
4、循环引用之导致内存泄漏
l1 = ['a','b']
l2 = ['x','y']
l1.append(l2)
l2.append(l1)
del l1
del l2
"""
l1、l2的直接引用都被删除了,但是还存在彼此之间的间接引用,但是却永远也无法获取到对应的值,便会导致内存泄漏
"""
针对上面的这种情况python提供了标记清除机制,当内存空间不够用的时候将整个程序暂停下来,扫描栈区,把通过栈区所有能够引用到的值(不管是直接引用还是间接引用)都标记为存活状态,通过栈区引用不到的值都标记为死亡状态,死亡状态的值都会被清除掉,即使它身上的引用计数不为0.
5、分代回收机制
标记清除机制存在弊端,如果代码过长,将栈区所有的值扫描一遍效率太低,因此提出分代回收机制,垃圾回收机制主要用引用计数来扫描并回收垃圾,用标记清除解决引用计数回收不了的垃圾,用分代回收解决引用计数扫描的效率问题。
分代回收机制就是通过扫描次数,对变量设置权重,达到权重后,对于稳定的变量减少扫描的频率,以此来提高扫描效率。