Python八股文总结,字节跳动Python面试

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Python全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Python知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注Python)
img

正文

my_dict = {'name': 'John', 'age': 25, 'name': 'Alice'}

print(my_dict)

输出:

{'name': 'Alice', 'age': 25}

在上面的例子中,最终字典中的键 'name' 只保留了最后一次出现的值 'Alice'。这强调了字典中键的不可重复性。如果你需要存储多个具有相同键的值,可以考虑使用列表或其他数据结构来保存这些值。

三. Break和Continuous区别
  • break 用于终止循环,跳出循环体。
  • continue 用于跳过循环体中的剩余代码,直接进行下一轮循环。
四. return和yield的区别,以及return的作用
  • return 用于从函数中返回一个值,并终止函数的执行。
  • yield 用于生成一个迭代器,函数执行暂停并保存状态,可以在下一次调用中继续执行。函数的状态在多次调用中保持。
五. Python深拷贝和浅拷贝区别

浅拷贝只复制对象的第一层,深拷贝复制对象的所有层。修改原始对象中的嵌套对象不会影响浅拷贝,但会影响深拷贝。

浅拷贝和深拷贝是关于复制对象的两个概念,它们的主要区别在于复制的程度。

浅拷贝(Shallow Copy):
  1. 定义: 浅拷贝创建一个新对象,然后将原对象中的元素(对象的引用)复制到新对象中。新对象中的元素仍然是原对象中元素的引用。
  2. 复制层次: 只复制了对象的一层。如果对象中包含引用类型的元素(例如列表或字典),则新对象中的引用仍然指向原对象中的相同元素。
  3. 使用方法: 使用 copy() 函数或切片操作 [:] 来进行浅拷贝。
import copy

original_list = [1, [2, 3], 4]
shallow_copy = copy.copy(original_list)
深拷贝(Deep Copy):
  1. 定义: 深拷贝创建一个新对象,并递归地复制原对象中的所有元素,包括嵌套的元素。新对象中的元素是原对象中元素的副本,而不是引用。
  2. 复制层次: 复制了对象的所有层次结构,包括嵌套的对象。
  3. 使用方法: 使用 copy.deepcopy() 函数来进行深拷贝。
import copy

original_list = [1, [2, 3], 4]
deep_copy = copy.deepcopy(original_list)
  • 浅拷贝对于不可变对象(如整数、字符串)来说,效果和深拷贝相同,因为不可变对象没有嵌套的引用关系。
  • 深拷贝可能会更耗费资源,因为它需要递归地复制整个对象结构,而且可能导致循环引用的问题。
  • 如果原对象中包含自定义对象,需要确保自定义对象支持拷贝操作,即实现 __copy__()__deepcopy__() 方法。
关于拷贝的地址问题:
  • 在浅拷贝和深拷贝中,都会复制对象的地址,但它们对于嵌套的对象(即对象内部包含其他对象)的处理方式不同。
  • 浅拷贝:
  • 复制对象的一层结构,但对于嵌套的对象,只复制其引用,而不是创建副本。因此,浅拷贝中的元素仍然指向原始对象中相同的地址。
import copy

original_list = [1, [2, 3], 4]
shallow_copy = copy.copy(original_list)

# 原始对象和浅拷贝后的对象共享嵌套列表的地址
print(original_list[1] is shallow_copy[1])  # True
  • 深拷贝:
  • 递归地复制对象的所有层次结构,包括嵌套的对象。深拷贝中的元素是原始对象中元素的副本,而不是引用。
import copy

original_list = [1, [2, 3], 4]
deep_copy = copy.deepcopy(original_list)

# 原始对象和深拷贝后的对象的嵌套列表是相互独立的
print(original_list[1] is deep_copy[1])  # False

总结起来,浅拷贝和深拷贝都是复制对象的地址,但深拷贝会递归地复制整个对象结构,包括嵌套的对象,使得复制后的对象完全独立于原始对象。

六. range和xrange的区别

range 返回一个列表,xrange 返回一个生成器。在 Python 3 中,xrange 被移除,range 本身就是一个生成器。

七. is和==的区别
  • == 用于比较对象的值是否相等。
  • .is 用于比较对象的身份标识是否相等(是否是同一个对象)。
八. 什么是lambda函数

lambda 函数是一种匿名函数,通常用于简化代码,特别是在函数参数中传递简单的功能。

九. 字符串拆分方法有哪些

split()splitlines()partition() 等。

十. 单引号、双引号、三引号区别
  • 单引号和双引号在 Python 中用于表示字符串,没有实质性区别。
  • 三引号用于表示多行字符串(能够实现多行字符串的输入),也可以表示多行注释。
十一. python传参时需要注意什么

Python 中函数参数可以是位置参数、关键字参数、默认参数和可变参数。注意参数的顺序和类型匹配。

十二. 装饰器

装饰器是一种用于修改函数或方法行为的高级技术。装饰器可以在不改变函数代码和调用方式的情况下给函数添加新的功能。本质上是一个嵌套函数,接收被装饰的函数(func)作为参数,并返回一个包装过的函数,以实现不影响函数的情况下添加新的功能。抽离出大量与函数主体功能无关的代码,增加一个函数的重用性。
应用场景:性能测试(统计程序运行时间)、插入日志、权限校验

十三. 函数或变量的作用域

作用域是指在程序中定义变量或函数的区域,它决定了在何处可以访问变量或函数。作用域分为全局作用域和局部作用域。

局部作用域(Local Scope): 定义在函数内部的变量具有局部作用域。这意味着这些变量只能在函数内部访问,对于函数外部是不可见的。

def my_function():
    x = 10  # x在此处有局部作用域
    print(x)

my_function()
# print(x)  # 这里会报错,因为 x 在函数外不可见

现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。

分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
[外链图片转存中…(img-8Xt3lJ3X-1713351267859)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python八股文是指对于算法工程师来说,在面试或考试中常被问到的一些Python知识点和面试题目总结。下面是一些常见的Python八股文知识点: 1. Python的内存管理以及垃圾回收机制:Python使用引用计数来管理内存,并通过垃圾回收机制来处理循环引用的情况。 2. Python中的pass有什么作用:pass是一个空语句,用于占位,不做任何操作。 3. Python的strip:strip函数用于去除字符串两端的空白字符。 4. Python多线程中的IO型操作:在Python中,由于全局解释器锁(GIL)的存在,多线程并不能真正实现并行执行。对于IO型操作,多线程可以提高效率。 5. Python如何进行数据类型转换:可以使用int()、float()、str()等函数进行数据类型转换。 6. Python中的单下划线_和双下划线__:单下划线_是一个惯例,表示一个私有属性或方法,双下划线__是用于名称修饰,以避免名称冲突。 7. Python中的self、cls、@staticmethod、@classmethod:self是指实例本身,cls是指类本身,@staticmethod表示静态方法,@classmethod表示类方法。 8. Python中的super函数:super函数用于调用父类的方法。 9. Python中的特殊方法(魔法函数):特殊方法是以双下划线开头和结尾的方法,用于实现对象的特殊行为,比如__init__()用于初始化对象。 10. Python中的\_\_new\_\_()和\_\_init\_\_()和\_\_call\_\_()[1:\_\_new\_\_()用于创建对象,\_\_init\_\_()用于初始化对象,\_\_call\_\_()用于使对象可调用。 11. UTF-8和GBK的区别:UTF-8是一种可变长度的Unicode编码,支持多种语言,而GBK是用于中文字符的编码。 12. Python中的zip()函数:zip函数用于将多个可迭代对象打包成一个元组的列表。 以上是一些常见的Python八股文知识点,掌握了这些知识可以帮助你在面试或考试中更好地回答相关问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [python 知识点/面试题目总结八股文)算法工程师必备](https://blog.csdn.net/CSSDCC/article/details/127050797)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Python八股文](https://blog.csdn.net/weixin_43570470/article/details/127726404)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值