卖逼视频免费看片|狼人就干网中文字慕|成人av影院导航|人妻少妇精品无码专区二区妖婧|亚洲丝袜视频玖玖|一区二区免费中文|日本高清无码一区|国产91无码小说|国产黄片子视频91sese日韩|免费高清无码成人网站入口

java回調(diào)函數(shù)的使用場景 為什么Python工程師很少像Java工程師那樣討論垃圾回收?

為什么Python工程師很少像Java工程師那樣討論垃圾回收?如何管理白記憶中的杜?Python中主要有三種內(nèi)存管理機制:引用計數(shù)zhi機制、垃圾收集dao機制和內(nèi)存池機制。A.引用計數(shù)當(dāng)一個對象被賦

為什么Python工程師很少像Java工程師那樣討論垃圾回收?

如何管理白記憶中的杜?

Python中主要有三種內(nèi)存管理機制:引用計數(shù)zhi機制、垃圾收集dao機制和內(nèi)存池機制。

A.引用計數(shù)

當(dāng)一個對象被賦予一個新的名字或被放入一個容器(列表、元組或字典)時,該對象的引用計數(shù)將增加。

當(dāng)del用于表示一個對象被銷毀或者引用超過動作或者被重新分配時,該對象的引用計數(shù)將會減少。

您可以使用()函數(shù)來獲取對象的當(dāng)前引用計數(shù)。在大多數(shù)情況下,引用計數(shù)比我們猜測的要大得多。對于不可變的數(shù)據(jù)(數(shù)字和字符串),解釋器會在程序的不同部分共享內(nèi)存以節(jié)省內(nèi)存。

B.碎片帳集

當(dāng)對象的引用計數(shù)歸零時,它將被垃圾收集機制處理掉。

當(dāng)...的時候

當(dāng)兩個對象A和B相互引用時,del語句可以減少A和B的引用計數(shù),并銷毀用于引用底層對象的名稱。但是,由于每個對象都包含對其他對象的應(yīng)用程序,因此引用

計數(shù)不會歸零,對象也不會被銷毀。(導(dǎo)致內(nèi)存泄漏)。為了解決這個問題,解釋器將定期執(zhí)行循環(huán)檢測器來搜索不可訪問對象的循環(huán)并刪除它們。

C.內(nèi)存池機制

Python為內(nèi)存提供了垃圾收集機制,但是它將未使用的內(nèi)存放入內(nèi)存池,而不是返回給操作系統(tǒng)。

1)Pymalloc機制。為了加快Python的執(zhí)行效率,Python引入了內(nèi)存池機制來管理小塊內(nèi)存的申請和釋放。

2)Python中所有小于256字節(jié)的對象都使用pymalloc實現(xiàn)的分配器,而大型對象使用系統(tǒng)的malloc。

3) Python對象,比如整數(shù)、浮點數(shù)、List,都有自己的私有內(nèi)存池,對象不共享自己的內(nèi)存池。也就是說,如果你分配釋放了大量的整數(shù),那么用來緩存這些整數(shù)的內(nèi)存就不能再分配給浮點數(shù)了。

【Python環(huán)境】12個Python面試問題匯總

2.什么是lambda函數(shù)?它有什么好處?

Lambda表達式通常在你需要一個函數(shù)的時候使用,但是你不需要。;t不想費事給它起名字,就是匿名函數(shù)。

Lambda函數(shù):主要目的是指出短回調(diào)函數(shù)。

lambda[參數(shù)]:表達式

gtgtgt alambda x,y:x y

gtgtgt a(3,11)

3.如何在Python中實現(xiàn)元組和列表的轉(zhuǎn)換?

直接用tuple和list函數(shù)就行了,type()可以確定對象的類型。

4.請寫一個Python代碼實現(xiàn)。刪除列表中的重復(fù)元素。

這個地方可以用set來實現(xiàn)。

5.如何在Python中復(fù)制一個對象?(賦值、淺拷貝和深拷貝的區(qū)別)

賦值()是創(chuàng)建一個對象的新引用,修改任何一個變量都會影響到另一個。

淺拷貝:創(chuàng)建一個新的對象,但是它包含了對原對象所包含的項的引用(如果引用修改了一個對象,那么另一個對象也會被修改改變){1、全切片法;2、工廠函數(shù),比如list();3、復(fù)制模塊的copy()函數(shù)}

深層復(fù)制:新建一個對象,遞歸復(fù)制它包含的對象(修改一個,另一個不變){()復(fù)制模塊的函數(shù)}

6.介紹except的用法和作用?

嘗試…除了…除了…[其他…][最后…]

執(zhí)行try下的語句,如果拋出異常,執(zhí)行會跳轉(zhuǎn)到except語句。嘗試按順序執(zhí)行except中的每個分支,如果拋出的異常與except中的異常組匹配,則執(zhí)行相應(yīng)的語句。如果所有異常都不匹配,異常將被傳遞給調(diào)用此代碼的下一個最高級別的try代碼。

如果try下的語句正常執(zhí)行,則執(zhí)行else塊代碼。如果出現(xiàn)異常,將不會執(zhí)行。

如果finally語句存在,它最終將總是被執(zhí)行。

【Python環(huán)境】12個Python面試問題匯總

7.什么?;Python中match()和search()的區(qū)別是什么?

re模塊中的Match(pattern,string [,flags]),并檢查字符串的開頭是否與模式匹配。

在re模塊中,research(pattern,string [,flags])在string中搜索模式的第一個匹配值。

gtgtgt print((;超級;,;迷信;)。span())

(0, 5)

gtgtgt print((;超級;,;無法超越;))

沒有人

gtgtgt print((;超級;,;迷信;)。span())

(0, 5)

gtgtgt print((;超級;,;無法超越;)。span())

(2, 7)

8.用Python匹配HTML標簽時,lt.*gt和lt.*?什么?;gt的區(qū)別是什么?

這些術(shù)語稱為貪婪匹配(lt.*gt)和非貪婪匹配(lt.*?gt)

例如:

試驗

lt.*gt:

試驗

lt。*?gt:

9.以下代碼的輸出會是什么?說出你的答案并解釋。

輸出:

讓你不解或驚訝的是,最后一行的輸出是3 ^ 2 ^ 3而不是3 ^ 2 ^ 1。為什么改變Parent.x的值會改變Child2.x的值,但同時Child1.x的值不變?

這個答案的關(guān)鍵是在Python中

類變量在內(nèi)部被視為字典。如果在當(dāng)前類的字典中沒有找到變量名,將搜索祖先類(如父類),直到找到被引用的變量名(如果被引用的變量名

變量名在其自己的類或其祖先類中找不到,這將引發(fā)AttributeError異常)。

因此,在父類中設(shè)置x 1將使對該類及其任何子類的引用中的類變量x 1的值。這是因為第一個print語句的輸出是1 1 1。

隨后,如果它的任何子類重寫了該值(例如,我們執(zhí)行語句Child1.x 2),那么該值只在子類中發(fā)生變化。這就是為什么第二個print語句的輸出是1 2 1。

最后,如果父類中的值發(fā)生變化(例如,我們執(zhí)行語句Parent.x 3),這種變化將影響任何沒有覆蓋該值的子類中的值(在本例中,受影響的子類是Child2)。這就是為什么第三次打印輸出是3 2 3。

10.下面的代碼會輸出什么?

回答

上述代碼將輸出[],并且不會導(dǎo)致Ind

什么是線程池,如何使用,為什么要用?

首先,線程池的作用:

線程池的作用是限制系統(tǒng)中執(zhí)行線程的數(shù)量。

根據(jù)系統(tǒng)的環(huán)境,可以自動或手動設(shè)置線程數(shù)量,以達到最佳運行效果;少了浪費系統(tǒng)資源,多了造成系統(tǒng)擁塞,效率低下。使用線程池控制線程數(shù)量,其他線程排隊等待。在一個任務(wù)被執(zhí)行后,從隊列中取出前面的任務(wù)并開始執(zhí)行。如果隊列中沒有正在等待的進程,那么線程池的這個資源正在等待。當(dāng)一個新任務(wù)需要運行時,如果線程池中有等待的工作線程,就可以開始運行;否則,進入等待隊列。

二、如何使用:

配置一個線程池比較復(fù)雜,尤其是如果不清楚線程池的原理,很有可能配置的線程池不是最優(yōu)的,所以在Executors類中提供了一些靜態(tài)工廠來生成一些常用的線程池。

創(chuàng)建單線程線程池。這個線程池中只有一個線程在工作,相當(dāng)于單個線程串行執(zhí)行所有任務(wù)。如果這個唯一的線程由于異常而結(jié)束,一個新的線程將取代它。這個線程池確保所有任務(wù)按照提交的順序執(zhí)行。

創(chuàng)建一個固定大小的線程池。每次提交任務(wù)時創(chuàng)建一個線程,直到線程達到線程池的最大大小。一旦線程池的大小達到最大值,它將保持不變。如果一個線程由于執(zhí)行異常而結(jié)束,線程池將被一個新線程補充。

?

1.創(chuàng)建和銷毀線程的數(shù)量減少了,每個工作線程可以重用來執(zhí)行多個任務(wù)。2.根據(jù)系統(tǒng) s的承載能力,可以調(diào)整線程池中工作線程的數(shù)量,防止服務(wù)器因內(nèi)存消耗過大而耗盡(每個線程需要1MB左右的內(nèi)存,打開的線程越多,消耗的內(nèi)存越多,最后崩潰)。

Java中線程池的頂層接口是Executor,但嚴格來說Executor并不是線程池,只是一個執(zhí)行線程的工具。真正的線程池接口是ExecutorService。