Python 面试题
1、 Python 数据结构有哪些
整数(int)
浮点(float)
字符串(str)
布尔(bool)
列表(list)
元组(tuple)
字典(dict)
集合(set)
2、Python 中列表和元组的区别是什么?元组是不是真的不可变?
列表:list 是可变类型、数据可以动态变化
元组:是不可变类型,大小固定
3、什么是生成器和迭代器?它们之间有什么区别?
迭代器
作用:简化循环的代码并可以节约内存
是一个可以记住遍历的位置的对象。迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退
迭代器有两个基本的方法:iter() 和 next()。
生成器
作用:节约大量内存
使用了 yield 的函数被称为生成器、生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器
原理:在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回 yield 的值, 并在下一次执行 next() 方法时从当前位置继续运行
4、什么是闭包?装饰器又是什么?装饰器有什么作用?你用过装饰器吗?请写一个装饰器的例子
闭包是指 Python 中将组成函数的语言和这些语言的执行环境打包到一起所得到的对象
装饰器是一种增加函数或类功能的简单方法,它可以快速给不同的函数或类插入相同的功能。语法:“@装饰器名”加在函数之前
5、什么是匿名函数,用匿名函数有什么好处?
匿名函数:使用 lambda 创建的函数,所谓匿名,意即不再使用 def 语句这样标准的形式定义一个函数。
好处:
1、使用 Python 写一些执行脚本时,使用 lambda 可以省去定义函数的过程,让代码更加精简。
2、对于一些抽象的,不会别的地方再复用的函数,有时候给函数起个名字也是个难题,使用 lambda 不需要考虑命名的问题。
3、使用 lambda 在某些时候让代码更容易理解。
应用场景:经常与一些内置函数相结合使用,比如说map()、filter()、sorted()、reduce()
等
表达式格式:lambda 参数列表: lambda体
案例:
6、如何提高 Python 的运行效率吗
使用生成器优化内存
循环的优化:多个 if elif 条件判断,可以把最有可能先发生的条件放到前面写,这样可以减少程序判断的次数,提高效率
优化算法时间:算法的时间复杂度对程序的执行效率影响最大,在 Python 中可以通过选择合适的数据结构来优化时间复杂度,如 list 和 set 查找某一个元素的时间复杂度分别是 O(n)和 O(1)
7、用过类吗?知道继承吗?请写一个例子,用到继承。
继承:指通过获取父对象的属性和能力,再加上自定义的属性和能力而成为一个对象的子对象或一个类的子类。
重写:方法名取一样,方法重写
8、深拷贝和浅拷贝
浅拷贝,改变原始对象中为可变类型的元素的值,会同时影响拷贝对象;改变原始对象中为不可变类型的元素的值,不会响拷贝对象。
深拷贝,除了顶层拷贝,还对子元素也进行了拷贝。经过深拷贝后,原始对象和拷贝对象所有的可变元素地址都没有相同的了
9、列举 8 个常用模块都有那些?
os模块
:提供了不少与操作系统相关联的函数.
sys模块
:通用工具脚本经常调用命令行参数.
re模块
:为高级字符串处理提供了正则表达式工具。对于复杂的匹配和处理,正则表达式提供了简洁、优化的解决方案:
random模块
:提供了生成随机数的工具。
json模块
:提供 Python 解析 json 数据的方法,和 python 格式相互转化的方法
time模块
:python 中用于处理时间的模块
logging模块
:python 中关于日志处理的模块
xml模块
:python 爬虫中用于定位 html 标签的模块
10、Python 垃圾回收机制?(知道即可)
python 采用的是引用计数机制为主,标记-清除和分代收集(隔代回收、分代回收)两种机制为辅的策略
计数机制:Python 的 GC 模块主要运用了引用计数来跟踪和回收垃圾。在引用计数的基础上,还可以通过“标记-清除”解决容器对象可能产生的循环引用的问题。通过分代回收以空间换取时间进一步提高垃圾回收的效率。
标记-清除::标记-清除的出现打破了循环引用,也就是它只关注那些可能会产生循环引用的对象缺点:该机制所带来的额外操作和需要回收的内存块成正比。
隔代回收原理:将系统中的所有内存块根据其存活时间划分为不同的集合,每一个集合就成为一个“代”,垃圾收集的频率随着“代”的存活时间的增大而减小。也就是说,活得越长的对象,就越不可能是垃圾,就应该减少对它的垃圾收集频率。那么如何来衡量这个存活时间:通常是利用几次垃圾收集动作来衡量,如果一个对象经过的垃圾收集次数越多,可以得出:该对象存活时间就越长。
评论