1. Python中__new__與__init__方法的區(qū)別
__new__:
觸發(fā)時(shí)機(jī): 在實(shí)例化對(duì)時(shí)觸發(fā)
參數(shù):至少一個(gè)cls 接收當(dāng)前類
返回值:必須返回一個(gè)對(duì)象實(shí)例
作用:實(shí)例化對(duì)象
注意:實(shí)例化對(duì)象是Object類底層實(shí)現(xiàn),其他類繼承了Object的__new__才能夠?qū)崿F(xiàn)實(shí)例化對(duì)象。
__init__:
觸發(fā)時(shí)機(jī):初始化對(duì)象時(shí)觸發(fā)(不是實(shí)例化觸發(fā),但是和實(shí)例化在一個(gè)操作中)
參數(shù):至少有一個(gè)self,接收對(duì)象
返回值:無(wú)
作用:初始化對(duì)象的成員
注意:使用該方式初始化的成員都是直接寫(xiě)入對(duì)象當(dāng)中,類中無(wú)法具有
2.什么是匿名函數(shù)?
Lambda函數(shù),不用擔(dān)心函數(shù)名沖突,不過(guò)python對(duì)匿名函數(shù)支持有限,只有一些簡(jiǎn)單的情況下可以用
#聲明一個(gè)簡(jiǎn)單的lambda表達(dá)式
mylamb = lambda x,y:x+y
#調(diào)用函數(shù)
result = mylamb(8,9)
print(result)
3.簡(jiǎn)要概述一下python中生成器和迭代器?
(1)迭代器:
迭代器協(xié)議:對(duì)象需要提供next()方法,它要么返回迭代中的下一項(xiàng),要么就引起一個(gè)StopIteration異常,以終止迭代。
可迭代對(duì)象:實(shí)現(xiàn)了迭代器協(xié)議對(duì)象。list、tuple、dict都是Iterable(可迭代對(duì)象),但不是Iterator(迭代器對(duì)象)。但可以使用內(nèi)建函數(shù)iter(),把這些都變成Iterable(可迭代器對(duì)象)。
for item in Iterable 循環(huán)的本質(zhì)就是先通過(guò)iter()函數(shù)獲取可迭代對(duì)象Iterable的迭代器,然后對(duì)獲取到的迭代器不斷調(diào)用next()方法來(lái)獲取下一個(gè)值并將其賦值給item,當(dāng)遇到StopIteration的異常后循環(huán)結(jié)束
(2)生成器:
將列表生成式中[]改變?yōu)?)數(shù)據(jù)結(jié)構(gòu)會(huì)改變,從列表變?yōu)樯善?/p>
列表受內(nèi)存限制,所以沒(méi)有必要?jiǎng)?chuàng)建完整的列表(節(jié)省大量?jī)?nèi)存空間),在python中我們可以采用生成器:邊循環(huán)邊計(jì)算的機(jī)制
生成器是只能遍歷一次的。生成器是一類特殊的迭代器。還能使用 def 定義函數(shù),但是,使用yield而不是return語(yǔ)句返回結(jié)果。yield語(yǔ)句一次返回一個(gè)結(jié)果,在每個(gè)結(jié)果中間,掛起函數(shù)的狀態(tài),以便下次從它離開(kāi)的地方繼續(xù)執(zhí)行。
4.Python的垃圾回收機(jī)制(garbage collection)。
(1)當(dāng)gc模塊的計(jì)數(shù)器達(dá)到閾值,垃圾自動(dòng)回收
(2)當(dāng)調(diào)用gc.collect(),垃圾收到回收
(3)程序退出的時(shí)候,python解釋器來(lái)回收垃圾
5.函數(shù)裝飾器的作用?
裝飾器本質(zhì)上是一個(gè)Python函數(shù),它可以讓其他函數(shù)在不需要做任何代碼變動(dòng)的前提下增加額外功能,裝飾器的返回值也是一個(gè)函數(shù)對(duì)象。
它經(jīng)常用于有切面需求的場(chǎng)景,比如:插入日志、性能測(cè)試、事務(wù)處理、緩存、權(quán)限校驗(yàn)等場(chǎng)景。
有了裝飾器,我們就可以抽離出大量與函數(shù)功能本身無(wú)關(guān)的雷同代碼并繼續(xù)重用。概括的講,裝飾器的作用就是為已經(jīng)存在的對(duì)象添加額外的功能。
6.進(jìn)程、線程的區(qū)別?
(1)定義的不同
進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個(gè)獨(dú)立單位.
線程是進(jìn)程的一個(gè)實(shí)體,是CPU調(diào)度和分派的基本單位,它是比進(jìn)程更小的能獨(dú)立運(yùn)行的基本單位.線程自己基本上不擁有系統(tǒng)資源,只擁有一點(diǎn)在運(yùn)行中必不可少的資源(如程序計(jì)數(shù)器,一組寄存器和棧),但是它可與同屬一個(gè)進(jìn)程的其他的線程共享進(jìn)程所擁有的全部資源.
(2)區(qū)別
一個(gè)程序至少有一個(gè)進(jìn)程,一個(gè)進(jìn)程至少有一個(gè)線程.
線程的劃分尺度小于進(jìn)程(資源比進(jìn)程少),使得多線程程序的并發(fā)性高。
進(jìn)程在執(zhí)行過(guò)程中擁有獨(dú)立的內(nèi)存單元,而多個(gè)線程共享內(nèi)存,從而極大地提高了程序的運(yùn)行效率
線線程不能夠獨(dú)立執(zhí)行,必須依存在進(jìn)程中
(3)優(yōu)缺點(diǎn)
線程和進(jìn)程在使用上各有優(yōu)缺點(diǎn):線程執(zhí)行開(kāi)銷小,但不利于資源的管理和保護(hù);而進(jìn)程正相反。
7.函數(shù)的閉包
閉包就是函數(shù)式編程的重要語(yǔ)法結(jié)構(gòu),提高了代碼可重復(fù)實(shí)用性。使用特定或特殊的方式,將局部變量(內(nèi)部函數(shù))引入到全局環(huán)境中使用,這就是閉包操作。
8.Python里的拷貝
Copy淺拷貝,只拷貝父元素,deepcopy深拷貝,遞歸拷貝可變對(duì)象的所有元素
9.apache和nginx的區(qū)別
(1)nginx 相對(duì) apache 的優(yōu)點(diǎn):
輕量級(jí),同樣起web 服務(wù),比apache 占用更少的內(nèi)存及資源
抗并發(fā),nginx 處理請(qǐng)求是異步非阻塞的,支持更多的并發(fā)連接,而apache 則是阻塞型的,在高并發(fā)下nginx 能保持低資源低消耗高性能
配置簡(jiǎn)潔
高度模塊化的設(shè)計(jì),編寫(xiě)模塊相對(duì)簡(jiǎn)單
社區(qū)活躍
(2)apache 相對(duì)nginx 的優(yōu)點(diǎn):
rewrite ,比nginx 的rewrite 強(qiáng)大
模塊超多,基本想到的都可以找到
少bug ,nginx 的bug 相對(duì)較多
超穩(wěn)定
10.什么是事務(wù)?
事務(wù)(Transaction)是并發(fā)控制的基本單位。所謂事務(wù),它是一個(gè)操作序列,這些操作要么都執(zhí)行,要么都不執(zhí)行,它是一個(gè)不可分割的工作單位。例如,銀行轉(zhuǎn)帳工作:從一個(gè)帳號(hào)扣款并使另一個(gè)帳號(hào)增款,這兩個(gè)操作要么都執(zhí)行,要么都不執(zhí)行。所以,應(yīng)該把他們看成一個(gè)事務(wù)。事務(wù)是數(shù)據(jù)庫(kù)維護(hù)數(shù)據(jù)一致性的單位,在每個(gè)事務(wù)結(jié)束時(shí),都能保持?jǐn)?shù)據(jù)一致性
事務(wù)四大特性
原子性:事務(wù)中的全部操作在數(shù)據(jù)庫(kù)中是不可分割的,要么全部完成,要么均不執(zhí)行
一致性:幾個(gè)并行執(zhí)行的事務(wù),其執(zhí)行結(jié)果必須與按某一順序串行執(zhí)行的結(jié)果相一致
隔離性:事務(wù)的執(zhí)行不受其他事務(wù)的干擾,事務(wù)執(zhí)行的中間結(jié)果對(duì)其他事務(wù)必須是透明的
持久性:對(duì)于任意已提交事務(wù),系統(tǒng)必須保證該事務(wù)對(duì)數(shù)據(jù)庫(kù)的改變不被丟失,即使數(shù)據(jù)庫(kù)出現(xiàn)故障
11. 主鍵和外鍵的區(qū)別?
主鍵在本表中是唯一的、不可唯空的,外鍵可以重復(fù)可以唯空;外鍵和另一張表的主鍵關(guān)聯(lián),不能創(chuàng)建對(duì)應(yīng)表中不存在的外鍵。
12. 在數(shù)據(jù)庫(kù)中查詢語(yǔ)句速度很慢,如何優(yōu)化?
(1)建索引
(2)減少表之間的關(guān)聯(lián)
(3)優(yōu)化sql,盡量讓sql很快定位數(shù)據(jù),不要讓sql做全表查詢,應(yīng)該走索引,把數(shù)據(jù) 量大的表排在前面
(4)簡(jiǎn)化查詢字段,沒(méi)用的字段不要,已經(jīng)對(duì)返回結(jié)果的控制,盡量返回少量數(shù)據(jù)
(5)數(shù)據(jù)庫(kù)做好讀寫(xiě)分離
13. Oracle和Mysql的區(qū)別?
1)庫(kù)函數(shù)不同。
2)Oracle是用表空間來(lái)管理的,Mysql不是。
3)顯示當(dāng)前所有的表、用戶、改變連接用戶、顯示當(dāng)前連接用戶、執(zhí)行外部腳本的語(yǔ)句的不同。
4)分頁(yè)查詢時(shí)候時(shí)候不同
5)sql的語(yǔ)法的不同。
14.tcp和udp的區(qū)別?
tcp是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議。是專門(mén)為了在不可靠的互聯(lián)網(wǎng)絡(luò)上提供一個(gè)可靠的端到端字節(jié)流而設(shè)計(jì)的,面向字節(jié)流。
udp(用戶數(shù)據(jù)報(bào)協(xié)議)是iso參考模型中一種無(wú)連接的傳輸層協(xié)議,提供面向操作的簡(jiǎn)單不可靠的非連接傳輸層服務(wù),面向報(bào)文。
它們之間的區(qū)別:
1)、tcp是基于連接的,安全性高;udp是基于無(wú)連接的,安全性較低;
2)、由于tcp是連接的通信,需要有三次握手、重新確認(rèn)等連接過(guò)程,會(huì)有延時(shí),實(shí)時(shí)性差;同時(shí)過(guò)程復(fù)雜,也使其易于被攻擊;而udp無(wú)連接,無(wú)建立連接的過(guò)程,因而實(shí)時(shí)性較強(qiáng),也稍安全;
3)、tcp連接是點(diǎn)到點(diǎn)的電話接通通信;udp支持一對(duì)一、一對(duì)多、多對(duì)一、多對(duì)多的廣播通信。
15.對(duì)if __name__ == 'main'的理解?
“ if __name__ == '__main__':”
在Python中分為兩類:一種是直接執(zhí)行,另外一種是作為模塊時(shí)才被調(diào)用
__name__ 作為模塊的內(nèi)置屬性,即".py"文件的調(diào)用方式。如果等于“__main__"就直接執(zhí)行本文件,如果是別的就是作為模塊被調(diào)用。
更多關(guān)于“Python培訓(xùn)”的問(wèn)題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學(xué),課程大綱緊跟企業(yè)需求,更科學(xué)更嚴(yán)謹(jǐn),每年培養(yǎng)泛IT人才近2萬(wàn)人。不論你是零基礎(chǔ)還是想提升,都可以找到適合的班型,千鋒教育隨時(shí)歡迎你來(lái)試聽(tīng)。