01、前言

近期有小伙伴跟我反馈 ,面试有遇到面试官问 python 内存管理机制相关的问题,因为之前没有特地的去了解过,所以不知道怎么回答。

所以今天就专门写了这篇 python 内存管理机制的文章,来给大家系统的梳理一下内存管理机制的知识点,以及面试中容易被问到的问题。

通过这篇文章帮你们轻松通关面试中 python 内存管理机制相关的问题。

02、引用计数机制

引用计算机制是咱们 python 中垃圾回收的主要机制,python 解释器会根据对象的引用计数是否为零,来对进行垃圾回收,释放内存。接下来我们先来看看什么是引用计数。

我们先来看一个最简单的 python 赋值语句

a = 10

这边给变量 a 赋值了一个数值类型的对象 10, 那么在内存中存储的时候,a 这个变量指向的是 10 这个对象,此时 10 这个对象的引用计算会加 1。

b=a

当我们再把 a 赋值给变量 b 时,b 引用的也是 a 这个变量引用的值 10,那么这个时候 10 这个对象的引用计数又会加 1。

引用计数增加:

● 对象被创建

● 对象被别的变量引用(赋值给一个变量)

● 对象被作为元素,放在容器中(比如被当作元素放在列表中)

引用计数减少:

● 对象的别名被显式的销毁

● 对象的一个别名被赋值给其他对象 (例:比如原来的 a=10,被改成 a=100,那么此时 10 的引用计数就减少了)

● 对象从容器中被移除,或者容器被销毁(例:对象从列表中被移除,或者列表被销毁)

● 一个引用离开了它的作用域(调用函数的时候传进去的参数,在函数运行结束后,该参数的引用即被销毁)

引用计数查看

咱们如果要查看对象的引用计数,可以通过内置模块 sys 提供的 getrefcount 方法去查看。

import sys
obj =[11,22,33]
print(sys.getrefcount(obj))

注意点:当使用某个引用作为参数,传递给 getrefcount()时,参数实际上创建了一个临时的引用。因此,getrefcount()所得到的结果,会比期望的多 1 ;对应一些常用的基本数据看到的引用计数值会比较大(因为 python 内部引用)

03、数据池和缓存

1、小整数池

a=1000
a1=1000
b = 10
b1 = 10
# a和a1是否为同一个对象?,b和b1是否为同一个对象?

问题:a 和 a1 是否为同一个对象?,b 和 b1 是否为同一个对象?

答案: b 和 b1 是同一个对象,a 和 a1 不是

为什么会出现上述情况呢?

当运行 python 程序时,Python 自动将-5~256 的整数进行了缓存,放在一个‘池’(小整数池)中,无论程序中那些变量指向这些范围内的整数或者字符串当你将这些整数赋值给变量时,并不会重新创建对象,而是使用已经创建好的缓存对象。

优点:对于一些常用的整数,直接从‘池’里拿来用,避免频繁的创建和销毁,提升效率,节约内存

2、intern 机制

intern 机制,也称为字符串驻留池,是针对于字符串内存管理的一种优化处理的机制。

In [4]: s1='abc'
In [5]: s2 ='abc'
In [6]: s2 is s2
Out[6]: TrueIn [7]: s3='abc?'
In [8]: s4 = 'abc?'
In [9]: s3 is s4
Out[9]: False
#为什么会出现这种情况,同样是字符串为什么上面两次赋值,是同一个对象,下面不是。

intern 机制的优点是,在创建新的字符串对象时(如果字符串只包含数字、字母、下划线),会先在字符串驻留池里面找是否有已经存在的值相同的对象,如果有,则直接拿过来用(引用),避免频繁的创建和销毁内存,提升效率。

3、缓存机制

● float、int 、list 等一些内置的数据类型,会缓存 80 个对象

● 元组 会根据元组数据的长度,分别缓存元组长度为 0-20 的对象。

● 其他的自定义类型一般都是缓存 2 个对象

04、垃圾回收机制

● python 的垃圾回收机制用一句话来形容就是:引用计数机制为主,标记-清除和分代收集两种机制为辅的策略

1、引用计数

● 引用计数:在之前讲对象的引用我们讲到了,每个对象创建之后都有一个引用计数,当引用计数为 0 的时候,那么此时的的垃圾回收机制会自动把它销毁,回收内存空间。

● 引用计数存在一个缺点:那就是当两个对象出现循环引用的时候,那么这个两个变量始终不会被销毁,这样就会导致内存泄漏。

2、标记清除:

首先标记对象(垃圾检测),然后清除垃圾(垃圾回收),首先初始所有对象标记为白色,并确定根节点对象(这些对象是不会被删除),标记它们为黑色(表示对象有效),将有效对象引用的对象标记为灰色(表示对象可达,但它们所引用的对象还没检查),检查完灰色对象引用的对象后,将灰色标记为黑色。重复直到不存在灰色节点为止。最后白色结点都是需要清除的对象。

3、分代回收

分代回收是一种以空间换时间的操作方式,Python 将内存根据对象的存活时间划分为不同的集合,每个集合称为一个代,Python 将内存分为了 3“代”,分别为年轻代(第 0 代)、中年代(第 1 代)、老年代(第 2 代),他们对应的是 3 个链表,它们的垃圾收集频率随着对象存活时间的增大而减小。

最后: 可以关注公众号:伤心的辣条 ! 进去有许多资料共享!资料都是面试时面试官必问的知识点,也包括了很多测试行业常见知识,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!


好文推荐

转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!

面试经:一线城市搬砖!又面软件测试岗,5000就知足了…

面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…

什么样的人适合从事软件测试工作?

那个准点下班的人,比我先升职了…

测试岗反复跳槽,跳着跳着就跳没了…

我狂揽16个offer:面试常问的这些问题你准备了吗?相关推荐

  1. 给大家提供一些面试常问的问题

    给大家提供一些面试常问的问题 1. 简述 private. protected. public. internal 修饰符的访问权限. 答 . private :     私有成员, 在类的内部才可以 ...

  2. 面向对象程序设计(c++)面试常问——for考研复试面试

    关于c++的一些面试常问问题(考研面试编程语言) 前言: 本人22考研党,已上岸,发一些复试准备整理的资料作为对考研准备的一个收尾.由于近几年基本都是线上复试,线上的话会更加注重概念的考察,本人在复试 ...

  3. linux进程命令面试,面试常问的 25+ 个 Linux 命令

    面试常问的 25+ 个 Linux 命令 作者: HollisChuang 链接: http://www.hollischuang.com/archives/800 作为一个 Java 开发人员, 有 ...

  4. Java基础(以及面试常问问题)

    1.Vector,ArrayList, LinkedList的区别(面试常问到的) 三者都是实现集合框架中的List,也就是所谓有序集合,因此具体功能比较近似,比如都提供按照位置进行定位.添加或删除的 ...

  5. 计算机考研复试面试常问问题 编程语言篇

    计算机考研复试面试常问问题 编程语言篇 个人整理,免费分享,不可用于商业用途,转载请注明出处! 但是有同学反应闲鱼上有人盗卖此免费分享资料,还有好多同学买了,所以希望大家多多点赞评论收藏,提高这份资料 ...

  6. linux bsp笔试题,Linux BSP工程师面试常问问题汇集.pdf

    Linux BSP工程师面试常问问题汇集 Linux BSP 工程师面试常问问题汇集 TD 1.本文章遵从" 署名-非商业性使用 3.0 中国大陆 (CC BY-NC 3.0 CN)&quo ...

  7. 计算机考研复试面试常问问题 计算机网络篇(上)

    计算机考研复试面试常问问题 计算机网络篇(上) 在复习过程中,我用心查阅并整理了在考研复试面试中可能问到的大部分问题,并分点整理了答案,可以直接理解背诵并加上自己的语言润色!极力推荐打印下来看,效率更 ...

  8. Linux C工程师面试常问技术要点

    前言 最近在考虑跳槽,整理一下面试常问的东西,在给自己复习的同时也希望给需要面试的朋友有帮助~ 系统编程常问技术点 物理内存+虚拟内存 内存分区(栈+堆) 进程+线程 锁 分片 中断+系统调用 同步+ ...

  9. 测开工程师-面试常问测试用例

    测开工程师-面试常问测试用例 一.网络测试的一般流程 二.弱网功能测试 四.微信红包测试 五.无网状态测试 三.微信朋友圈点赞测试 六.登陆界面测试 七.直播APP测试 八.微信搜索界面测试 九.水杯 ...

最新文章

  1. 可以卸载什么程序来对计算机进行瘦身,电脑越来越卡了,教你一分钟让电脑瘦身(C盘哪些文件可以删除)-怎么清理电脑内存...
  2. csh shell_shell编程(一):初始shell
  3. Centos7:update-initramfs -u:command not found
  4. 你写代码,难道是因为热爱吗?
  5. android SQLite数据库用法图文详解(附源码)
  6. 载波聚合或双连接的方式进行_处理载波聚合及双连接的装置及方法与流程
  7. linux 重复执行脚本,防止shell脚本重复执行的代码
  8. java图片滚动特效_js图片各种滚动效果
  9. hdu5347 MZL's chemistry(打表)
  10. CentOS下安装JDK笔记
  11. 他用代码卖手机,卖出年流水上亿
  12. lvs、lvdisplay、lvscan 查看逻辑卷
  13. phpeclipse
  14. 简要html漂浮广告代码,JS漂浮广告代码
  15. mysql 主键 sql语句_Mysql主键相关的sql语句集锦
  16. 如何更换ppt模板内容不变_怎么修改固定的ppt模板中的字和图片
  17. 三星:大小屏QLED和OLED两手都要抓,都要硬
  18. freemaker与es6模板字符串语法冲突问题
  19. Linux C编程 —— 通过文件描述符获得文件路径
  20. ThreeJS - 动态更换fbx模型的某个子Mesh现有的纹理贴图为指定的纹理贴图

热门文章

  1. xp本地服务器虚拟目录创建,WindowsXp系统怎么创建虚拟目录
  2. linux tty驱动名称,Linux下TTY驱动程序分析
  3. 启动mysql55命令_mysql服务的启动和停止登陆mysql增加新用命令和方法实例教程
  4. 如何解决string转CString乱码问题?
  5. Python 萌新 - 花10分钟学爬虫
  6. Ubuntu更改镜像源
  7. ubuntu下的tomcat监控脚本
  8. Cocos2d-X中国象棋的发展《五岁以下儿童》摆棋
  9. 微软私有云分享(R2)21 BMC提升B格
  10. 浅谈Entity Framework中的数据加载方式