Python面經(jīng)之16個(gè)高頻面試問(wèn)題總結(jié)
(一)Python 是如何進(jìn)行內(nèi)存管理的?
答:從三個(gè)方面來(lái)說(shuō),一對(duì)象的引用計(jì)數(shù)機(jī)制,二垃圾回收機(jī)制,三內(nèi)存池機(jī)制
⒈對(duì)象的引用計(jì)數(shù)機(jī)制
Python 內(nèi)部使用引用計(jì)數(shù),來(lái)保持追蹤內(nèi)存中的對(duì)象,所有對(duì)象都有引用計(jì)數(shù)。引用計(jì)數(shù)增加的情況:
?一個(gè)對(duì)象分配一個(gè)新名稱
?將其放入一個(gè)容器中(如列表、元組或字典) 引用計(jì)數(shù)減少的情況:
?使用 del 語(yǔ)句對(duì)對(duì)象別名顯示的銷毀
?引用超出作用域或被重新賦值
sys.getrefcount( )
函數(shù)可以獲得對(duì)象的當(dāng)前引用計(jì)數(shù)
多數(shù)情況下,引用計(jì)數(shù)比你猜測(cè)得要大得多。對(duì)于不可變數(shù)據(jù)(如數(shù)字和字符串),解釋器會(huì)在程序的不同部分共享內(nèi)存,以便節(jié)約內(nèi)存。
⒉垃圾回收
?當(dāng)一個(gè)對(duì)象的引用計(jì)數(shù)歸零時(shí),它將被垃圾收集機(jī)制處理掉。
?當(dāng)兩個(gè)對(duì)象 a 和 b 相互引用時(shí),del 語(yǔ)句可以減少 a 和 b 的引用計(jì)數(shù),并銷毀用于引用底層對(duì)象的名稱。然而由于每個(gè)對(duì)象都包含一個(gè)對(duì)其他對(duì)象的應(yīng)用,
因此引用計(jì)數(shù)不會(huì)歸零,對(duì)象也不會(huì)銷毀。(從而導(dǎo)致內(nèi)存泄露)。為解決這一問(wèn)題,解釋器會(huì)定期執(zhí)行一個(gè)循環(huán)檢測(cè)器,搜索不可訪問(wèn)對(duì)象的循環(huán)并刪除它們。
⒊內(nèi)存池機(jī)制
Python 提供了對(duì)內(nèi)存的垃圾收集機(jī)制,但是它將不用的內(nèi)存放到內(nèi)存池而不是返回給操作系統(tǒng)。
?Pymalloc 機(jī)制。為了加速 Python 的執(zhí)行效率,Python 引入了一個(gè)內(nèi)存池機(jī)制,用于管理對(duì)小塊內(nèi)存的申請(qǐng)和釋放。
?Python 中所有小于 256 個(gè)字節(jié)的對(duì)象都使用 pymalloc 實(shí)現(xiàn)的分配器,而大的對(duì)象則使用系統(tǒng)的 malloc。
?對(duì)于 Python 對(duì)象,如整數(shù),浮點(diǎn)數(shù)和 List,都有其獨(dú)立的私有內(nèi)存池,對(duì)象間不共享他們的內(nèi)存池。也就是說(shuō)如果你分配又釋放了大量的整數(shù),用于緩存這些整數(shù)的內(nèi)存就不能再分配給浮點(diǎn)數(shù)。
(二)什么是 lambda 函數(shù)?它有什么好處?
答:lambda 表達(dá)式,通常是在需要一個(gè)函數(shù),但是又不想費(fèi)神去命名一個(gè)函數(shù)的場(chǎng)合下使用, 也就是指匿名函數(shù)
lambda 函數(shù):首要用途是指點(diǎn)短小的回調(diào)函數(shù)lambda [arguments]:expression
>>> a=lambdax,y:x+y >>> a(3,11)
(三)Python 里面如何實(shí)現(xiàn) tuple 和 list 的轉(zhuǎn)換?
答:直接使用 tuple 和 list 函數(shù)就行了,type()可以判斷對(duì)象的類型
(四)請(qǐng)寫出一段 Python 代碼實(shí)現(xiàn)刪除一個(gè)list 里面的重復(fù)元素
答
使用 set 函數(shù),set(list)
使用字典函數(shù),
>>>a=[1,2,4,2,4,5,6,5,7,8,9,0] >>> b={} >>>b=b.fromkeys(a) >>>c=list(b.keys()) >>> c
(五)編程用 sort 進(jìn)行排序,然后從最后一個(gè)元素開始判斷
a=[1,2,4,2,4,5,7,10,5,5,7,8,9,0,3] a.sort() last=a[-1] for i inrange(len(a)-2,-1,-1): if last==a: del a else:last=a print(a)
(六)Python 里面如何拷貝一個(gè)對(duì)象?(賦值,淺拷貝,深拷貝的區(qū)別)
答:賦值(=),就是創(chuàng)建了對(duì)象的一個(gè)新的引用,修改其中任意一個(gè)變量都會(huì)影響到另一個(gè)。淺拷貝:創(chuàng)建一個(gè)新的對(duì)象,但它包含的是對(duì)原始對(duì)象中包含項(xiàng)的引用(如果用引用的方式修改其中一個(gè)對(duì)象,另外一個(gè)也會(huì)修改改變){1,完全切片方法;2,工廠函數(shù),如 list();
3,copy 模塊的 copy()函數(shù)}
深拷貝:創(chuàng)建一個(gè)新的對(duì)象,并且遞歸的復(fù)制它所包含的對(duì)象(修改其中一個(gè),另外一個(gè)不會(huì)改變){copy 模塊的 deep.deepcopy()函數(shù)}
(七)介紹一下 except 的用法和作用?
答:try…except…except…[else…][finally…]
執(zhí)行 try 下的語(yǔ)句,如果引發(fā)異常,則執(zhí)行過(guò)程會(huì)跳到 except 語(yǔ)句。對(duì)每個(gè) except 分支順序嘗試執(zhí)行,如果引發(fā)的異常與 except 中的異常組匹配,執(zhí)行相應(yīng)的語(yǔ)句。
如果所有的 except 都不匹配,則異常會(huì)傳遞到下一個(gè)調(diào)用本代碼的最高層 try 代碼中。
try 下的語(yǔ)句正常執(zhí)行,則執(zhí)行 else 塊代碼。如果發(fā)生異常,就不會(huì)執(zhí)行如果存在 finally 語(yǔ)句,最后總是會(huì)執(zhí)行。
(八)Python 中 pass 語(yǔ)句的作用是什么?
答:pass 語(yǔ)句不會(huì)執(zhí)行任何操作,一般作為占位符或者創(chuàng)建占位程序,whileFalse:pass
(九)介紹一下 Python 下 range()函數(shù)的用法?
答:列出一組數(shù)據(jù),經(jīng)常用在 for in range()
循環(huán)中
(十)如何用 Python 來(lái)進(jìn)行查詢和替換一個(gè)文本字符串?
答:可以使用 re 模塊中的 sub()函數(shù)或者 subn()函數(shù)來(lái)進(jìn)行查詢和替換,
格式:sub(replacement, string[,count=0])
(replacement 是被替換成的文本,string 是需要被替換的文本,count 是一個(gè)可選參數(shù),指最大被替換的數(shù)量)
>>> import re >>>p=re.compile(‘blue|white|red') >>>print(p.sub(‘colour','blue socks and red shoes')) colour socks and colourshoes >>>print(p.sub(‘colour','blue socks and red shoes',count=1)) colour socks and redshoes
subn()方法執(zhí)行的效果跟 sub()一樣,不過(guò)它會(huì)返回一個(gè)二維數(shù)組,包括替換后的新的字符串和總共替換的數(shù)量
(十一)Python 里面 match()和 search()的區(qū)別?
答:re 模塊中 match(pattern,string[,flags])
,檢查 string 的開頭是否與 pattern 匹配。
re 模塊中re.search(pattern,string[,flags])
,在 string 搜索 pattern 的第一個(gè)匹配值。
>>>print(re.match(‘super', ‘superstition').span()) (0, 5) >>>print(re.match(‘super', ‘insuperable')) None >>>print(re.search(‘super', ‘superstition').span()) (0, 5) >>>print(re.search(‘super', ‘insuperable').span()) (2, 7)
(十二)用 Python 匹配 HTML tag 的時(shí)候,<.*>和<.*?>有什么區(qū)別?
答:術(shù)語(yǔ)叫貪婪匹配( <.*> )和非貪婪匹配(<.*?> )
例如:
test <.*> : test <.*?> :
(十三)Python 里面如何生成隨機(jī)數(shù)?
答:random 模塊
隨機(jī)整數(shù):random.randint(a,b)
:返回隨機(jī)整數(shù) x,a<=x<=b
random.randrange(start,stop,[,step])
:返回一個(gè)范圍在(start,stop,step)之間的隨機(jī)整數(shù),不包括結(jié)束值。
隨機(jī)實(shí)數(shù):random.random( )
:返回 0 到 1 之間的浮點(diǎn)數(shù)
random.uniform(a,b)
:返回指定范圍內(nèi)的浮點(diǎn)數(shù)。
(十四)有沒(méi)有一個(gè)工具可以幫助查找 python 的 bug 和進(jìn)行靜態(tài)的代碼分析?
答:PyChecker 是一個(gè) python 代碼的靜態(tài)分析工具,它可以幫助查找 python 代碼的 bug, 會(huì)
對(duì)代碼的復(fù)雜度和格式提出警告
Pylint 是另外一個(gè)工具可以進(jìn)行 codingstandard 檢查
(十五)如何在一個(gè) function 里面設(shè)置一個(gè)全局的變量?
答:解決方法是在 function 的開始插入一個(gè) global 聲明: def f()
global x
(十六)單引號(hào),雙引號(hào),三引號(hào)的區(qū)別
答:?jiǎn)我?hào)和雙引號(hào)是等效的,如果要換行,需要符號(hào)(\),三引號(hào)則可以直接換行,并且可以包含注釋
如果要表示 Let’s go 這個(gè)字符串單引號(hào):s4 = ‘Let\’s go’
雙引號(hào):s5 = “Let’s go”
s6 = ‘I realy like“python”!'
這就是單引號(hào)和雙引號(hào)都可以表示字符串的原因了
總結(jié)
到此這篇關(guān)于Python面經(jīng)之16個(gè)高頻面試問(wèn)題總結(jié)的文章就介紹到這了,更多相關(guān)Python面試問(wèn)題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python進(jìn)程,多進(jìn)程,獲取進(jìn)程id,給子進(jìn)程傳遞參數(shù)操作示例
這篇文章主要介紹了Python進(jìn)程,多進(jìn)程,獲取進(jìn)程id,給子進(jìn)程傳遞參數(shù)操作,結(jié)合實(shí)例形式分析了Python多進(jìn)程、父子進(jìn)程以及進(jìn)程參數(shù)傳遞相關(guān)操作技巧,需要的朋友可以參考下2019-10-10django1.11.1 models 數(shù)據(jù)庫(kù)同步方法
今天小編就為大家分享一篇django1.11.1 models 數(shù)據(jù)庫(kù)同步方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05Python?time時(shí)間格式化和設(shè)置時(shí)區(qū)實(shí)現(xiàn)代碼詳解
這篇文章主要介紹了Python?time時(shí)間格式化和設(shè)置時(shí)區(qū)實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值2023-02-02Python 使用SFTP和FTP實(shí)現(xiàn)對(duì)服務(wù)器的文件下載功能
這篇文章主要介紹了Python 使用SFTP和FTP實(shí)現(xiàn)對(duì)服務(wù)器的文件下載功能,本文通過(guò)實(shí)例代碼給大家介紹的非常想詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Django-Model數(shù)據(jù)庫(kù)操作(增刪改查、連表結(jié)構(gòu))詳解
這篇文章主要介紹了Django-Model數(shù)據(jù)庫(kù)操作(增刪改查、連表結(jié)構(gòu))詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07Python數(shù)據(jù)結(jié)構(gòu)之樹的全面解讀
數(shù)據(jù)結(jié)構(gòu)中有很多樹的結(jié)構(gòu),其中包括二叉樹、二叉搜索樹、2-3樹、紅黑樹等等。本文中對(duì)數(shù)據(jù)結(jié)構(gòu)中常見的樹邏輯結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu)進(jìn)行了匯總,不求嚴(yán)格精準(zhǔn),但求簡(jiǎn)單易懂2021-11-11