宁波GQY视讯股份有限公司2月招聘面试题66道2020223
Python是如何进行内存管理的?
一、对象的引用计数机制
Python内部使用引用计数,来保持追踪内存中的对象,所有对象都有引用计数。
引用计数增加的情况:
1,一个对象分配一个新名称
2,将其放入一个容器中(如列表、元组或字典)
引用计数减少的情况:
1,使用del语句对对象别名显示的销毁
2,引用超出作用域或被重新赋值sys.getre f count( )函数可以获得对象的当前引用计数
多数情况下,引用计数比你猜测得要大得多。对于不可变数据(如数字和字符串),解释器会在程序的不同部分共享内存,以便节约内存。
二、垃圾回收
1,当一个对象的引用计数归零时,它将被垃圾收集机制处理掉。
2,当两个对象a和b相互引用时,del语句可以减少a和b的引用计数,并销毁用于引用底层对象的名称。然而由于每个对象都包含一个对其他对象的应用,因此引用计数不会归零,对象也不会销毁。(从而导致内存泄露)。为解决这一问题,解释器会定期执行一个循环检测器,搜索不可访问对象的循环并删除它们。
三、内存池机制
Python提供了对内存的垃圾收集机制,但是它将不用的内存放到内存池而不是返回给操作系统。
1,Pymalloc机制。为了加速Python的执行效率,Python引入了一个内存池机制,用于管理对小块内存的申请和释放。
2,Python中所有小于256个字节的对象都使用pymalloc实现的分配器,而大的对象则使用系统的malloc。
3,对于Python对象,如整数,浮点数和List,都有其独立的私有内存池,对象间不共享他们的内存池。也就是说如果你分配又释放了大量的整数,用于缓存这些整数的内存就不能再分配给浮点数。
查看对象内存地址的Python内置函数是__________。
简单解释Python基于值的内存管理模式。
对于Python类中的私有成员,可以通过“对象名._类名__私有成员名”的方式来访问。
此题为判断题(对,错)。
查看变量内存地址的Python内置函数是_________________。
宁波GQY视讯股份有限公司2月招聘面试题面试题面试官常问到的一些题目整理如下:问题 Q1:如何在Python中内存管理?可用的回答 :Python内存由Python私有堆空间管理。 所有Python对象和数据结构都位于私有堆中。 程序员无权访问此私有堆,解释器负责处理此私有堆。 Python对象的Python堆空间分配由Python内存管理器完成。核心API提供了一些程序员编写代码的工具。 Python还有一个内置的垃圾收集器,它可以回收所有未使用的内存并释放内存并使其可用于堆空间。问题 Q2:Python是如何进行内存管理的?可用的回答 : 从三个方面来说,一对象的引用计数机制,二垃圾回收机制,三内存池机制 一、对象的引用计数机制 Python内部使用引用计数,来保持追踪内存中的对象,所有对象都有引用计数。 引用计数增加的情况: 1,一个对象分配一个新名称 2,将其放入一个容器中(如列表、元组或字典),引用计数减少的情况: 1,使用del语句对对象别名显示的销毁 2,引用超出作用域或被重新赋值 sys.getrefcount( )函数可以获得对象的当前引用计数 多数情况下,引用计数比你猜测得要大得多。对于不可变数据(如数字和字符串),解释器会在程序的不同部分共享内存,以便节约内存。 二、垃圾回收 1,当一个对象的引用计数归零时,它将被垃圾收集机制处理掉。 2,当两个对象a和b相互引用时,del语句可以减少a和b的引用计数,并销毁用于引用底层对象的名称。然而由于每个对象都包含一个对其他对象的应用,因此引用计数不会归零,对象也不会销毁。(从而导致内存泄露)。为解决这一问题,解释器会定期执行一个循环检测器,搜索不可访问对象的循环并删除它们。 三、内存池机制 Python提供了对内存的垃圾收集机制,但是它将不用的内存放到内存池而不是返回给操作系统。 1,Pymalloc机制。为了加速Python的执行效率,Python引入了一个内存池机制,用于管理对小块内存的申请和释放。 2,Python中所有小于256个字节的对象都使用pymalloc实现的分配器,而大的对象则使用系统的malloc。 3,对于Python对象,如整数,浮点数和List,都有其独立的私有内存池,对象间不共享他们的内存池。也就是说如果你分配又释放了大量的整数,用于缓存这些整数的内存就不能再分配给浮点数。 问题 Q3:简单谈下GIL?可用的回答 : Python代码的执行由Python 虚拟机(也叫解释器主循环,CPython版本)来控制, Python 在设计之初就考虑到要在解释器的主循环中,同时只有一个线程在执行,即在任意时刻,只有一个线程在解释器中运行。 对Python 虚拟机的访问由全局解释器锁(GIL)来控制,正是这个锁能保证同一时刻只有一个线程在运行。 在多线程环境中,Python 虚拟机按以下方式执行: 1. 设置GIL 2. 切换到一个线程去运行 3. 运行: a. 指定数量的字节码指令,或者 b. 线程主动让出控制(可以调用time.sleep(0)) 4. 把线程设置为睡眠状态 5. 解锁GIL 6. 再次重复以上所有步骤 在调用外部代码(如C/C+扩展函数)的时候,GIL 将会被锁定, 直到这个函数结束为止(由于在这期间没有Python 的字节码被运行,所以不会做线程切换)。 问题 Q4:Python中的module和package是什么?可用的回答 :在Python中,模块是构造程序的方式。每个Python程序文件都是一个模块,它导入其他模块,如对象和属性。Python程序的文件夹是一个模块包。包可以包含模块或子文件夹。问题 Q5:ngnix的正向代理与反向代理?可用的回答 : 正向代理 是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容, 客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。 客户端必须要进行一些特别的设置才能使用正向代理。 反向代理正好相反,对于客户端而言它就像是原始服务器,并且客户端不需要进行任何特别的设置。 客户端向反向代理的命名空间中的内容发送普通请求,接着反向代理将判断向何处(原始服务器)转交请求, 并将获得的内容返回给客户端,就像这些内容原本就是它自己的一样。 问题 Q6:Python中的module和package是什么?可用的回答 :在Python中,模块是构造程序的方式。每个Python程序文件都是一个模块,它导入其他模块,如对象和属性。Python程序的文件夹是一个模块包。包可以包含模块或子文件夹。问题 Q7:Python中的docstring是什么?可用的回答 :Python文档字符串称为docstring,它是一种记录Python函数,模块和类的方法。可以通过内置方法_doc_获取问题 Q8:描述数组、链表、队列、堆栈的区别?可用的回答 : 数组与链表是数据存储方式的概念,数组在连续的空间中存储数据,而链表可以在非连续的空间中存储数据; 队列和堆栈是描述数据存取方式的概念,队列是先进先出,而堆栈是后进先出; 队列和堆栈可以用数组来实现,也可以用链表实现。 问题 Q9:Python中的self是什么?可用的回答 :self是类的实例或对象。在Python中,self包含在第一个参数中。init方法中的self变量引用新创建的对象,而在其他方法中,它引用其方法被调用的对象。问题 Q10:什么是Python中的迭代器?可用的回答 :在Python中,迭代器用于迭代一组元素,如列表之类的容器。算法题面试官常问到的一些算法题目整理如下(大概率会机考):算题题 A1:从已排序的列表中删除重复数据II题目描述如下:Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.Example 1:Input: 1-2-3-3-4-4-5Output: 1-2-5Example 2:Input: 1-1-1-2-3Output: 2-3这次要把全部的重复都删除。我的思路是利用标记,过一遍,先把重复的删
Python采用的是基于值得自动内存管理方式。
此题为判断题(对,错)。
Python中没有严格意义上的私有成员。
此题为判断题(对,错)。
查看变量内存地址的Python内置函数是()。
正确答案:id()
Python采用的是基于值得自动内存管理方式。
正确答案:正确
简单解释Python基于值的自动内存管理方式?
正确答案:Python采用的是基于值得内存管理方式,在Python中可以为不同变量赋值为相同值,这个值在内存中只有一份,多个变量指向同一个内存地址;Python具有自动内存管理功能,会自动跟踪内存中所有的值,对于没有任何变量指向的值,Python自动将其删除。
相关考题:
- 纤维绳端头应不致()。A、拧紧B、松散C、断裂
- 2008年3月18日17时左右,邹某到某商厦进行霓虹灯常规维护,约17时30分,邹某通知配电室送电;20时40分,值班人员与邹某联系未果;20时50分左右,值班人员到商厦五楼楼顶查看,发现邹某坠落于商厦楼顶霓虹灯架附近,在其身上未发现安全带。值班人员立即通知110、120,经理20急救中心现场抢救后,于21时45宣布邹某死亡。邹某死亡的直接原因是未系安全带。
- 单选题斯金纳认为行为分为两类,分别是( )。A学习行为和操作行为B刺激行为和反应行为C应答性行为和操作性行为D操作行为和反应行为
- 单选题布鲁纳认为,学习知识的最佳方式是( )。A发现学习B接受学习C有意义接受学习D内化学习
- 单选题课堂纪律是对学生课堂行为所施加的( )。A监控与管理B准则与控制C限制性影响D限制与规范
- 单选题从现代认知心理学观点看,作文构思能力可用个人的( )来解释。A专门领域程序性知识B非专门领域程序性知识C通过练习达到自动化的程序性知识D非自动化的程序性知识
- 高处作业中使用吊篮等吊装设备时遇有风力超过()时应停止吊装作业。A、三级B、四级C、五级
- 单选题在一定反应后呈现厌恶刺激可以使有机体反应概率降低或终止,这是( )。A正强化B负强化C惩罚D恐惧性条件作用
- 单选题关于肺动脉狭窄的说法错误的是( )。A狭窄的部位在膜部、漏斗部或肺动脉主干及其分支B常见的为三瓣叶交界融和成隔膜状,呈圆锥状或圆顶状向肺动脉突出,顶端有一孔C也可见肺动脉瓣膜显著增厚,且短小,瓣孔边缘增厚,不规则D心底短轴切面见收缩期瓣叶呈圆顶帐篷状膨入肺动脉,瓣尖悬于肺动脉中EM超显示肺动脉瓣曲线a波低平
- 新钢管表面应平直光滑,不应有裂缝、结疤、分层、错位、硬弯、毛刺、压痕和深的划道。()