开发者社区 问答 正文

Python是如何进行内存管理的?

Python是如何进行内存管理的?

展开
收起
真的很搞笑 2021-11-02 22:36:53 551 分享 版权
1 条回答
写回答
取消 提交回答
  • 一、垃圾回收:

    python不像C++,Java等语言一样,他们可以不用事先声明变量类型而直接对变量进行赋值。对python语言来讲,对象的类型和内存都是在运行时确定的。这也是为什么我们称python语言为动态类型的原因(这里我们把动态类型语言可以简单的归结为对变量内存地址的分配是在运行时自动判断变量类型并对变量进行赋值)。
    

    二、引用计数:

    python采用了类似windows内核对象一样的方式来对内存进行管理。每一个对象,都维护这一个对指向该对象的引用的计数。当变量被绑定在一个对象上的时候,该变量的引用计数就是1,(还有另外一些情况也会导致变量引用计数的增加),系统会自动维护这些标签,并定时扫描,当某标签的引用计数变为0的时候,该对象就会被回收。
    

    三、内存池机制

    python的内存机制成金字塔形:
    
    第-1,-2层主要有操作系统进行操作;
    
    第0层是C中的malloc,free等内存分配和释放函数进行操作;
    
    第1层和第2层是内存池,有python的接口函数PyMem_Malloc函数实现,当对象小于256字节时由该层直接分配内存;
    
    第三层是最上层,也就是我们对python对象的直接操作;
    

    在C中如果频繁的调用malloc与free时,是会产生性能问题的,在加上频繁的分配和释放小块的内存会产生内存碎片。

    python在这里主要干的工作有:

    如果请求分配的内存在1~256字节之间就使用自己的内存管理系统,否则直接使用malloc。

    这里还是会调用malloc分配内存,但每次回分配一块大小为256字节的大块内存。

    经由内存池登记的内存到最后还是会回收到内存池,并不会调用C的free释放掉,以便下次使用。对于简单的python对象,例如数值、字符串、元组(tuple不允许被更改)采用的是复制的方式(深拷贝),也就是说当讲另一个变量B赋值给变量A时,虽然A和B的内存空间仍然相同,但是当A的值发生变化时,会重新给A分配空间,A和B的地址变得不再相同。

    2021-11-03 08:38:43
    赞同 展开评论
问答分类:
问答标签:
问答地址: