日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python开发面试题及部分答案分享!

發布時間:2024/9/30 python 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python开发面试题及部分答案分享! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、Python中__new__與__init__方法的區別

__ new__:

觸發時機: 在實例化對時觸發

參數:至少一個cls 接收當前類

返回值:必須返回一個對象實例

作用:實例化對象

注意:實例化對象是Object類底層實現,其他類繼承了Object的__new__才能夠實現實例化對象。

__ init__:

觸發時機:初始化對象時觸發(不是實例化觸發,但是和實例化在一個操作中)

參數:至少有一個self,接收對象

返回值:無

作用:初始化對象的成員

注意:使用該方式初始化的成員都是直接寫入對象當中,類中無法具有

2、什么是匿名函數?

Lambda函數,不用擔心函數名沖突,不過python對匿名函數支持有限,只有一些簡單的情況下可以用

#聲明一個簡單的lambda表達式

mylamb = lambda x,y:x+y

#調用函數

result = mylamb(8,9)

print(result)

3、簡要概述一下python中生成器和迭代器?

(1)迭代器:

迭代器協議:對象需要提供next()方法,它要么返回迭代中的下一項,要么就引起一個StopIteration異常,以終止迭代。

可迭代對象:實現了迭代器協議對象。list、tuple、dict都是Iterable(可迭代對象),但不是Iterator(迭代器對象)。但可以使用內建函數iter(),把這些都變成Iterable(可迭代器對象)。

for item in Iterable 循環的本質就是先通過iter()函數獲取可迭代對象Iterable的迭代器,然后對獲取到的迭代器不斷調用next()方法來獲取下一個值并將其賦值給item,當遇到StopIteration的異常后循環結束

(2)生成器:

將列表生成式中[]改變為()數據結構會改變,從列表變為生成器

列表受內存限制,所以沒有必要創建完整的列表(節省大量內存空間),在python中我們可以采用生成器:邊循環邊計算的機制

生成器是只能遍歷一次的。生成器是一類特殊的迭代器。還能使用 def 定義函數,但是,使用yield而不是return語句返回結果。yield語句一次返回一個結果,在每個結果中間,掛起函數的狀態,以便下次從它離開的地方繼續執行。

4、Python的垃圾回收機制(garbage collection)。

(1)當gc模塊的計數器達到閾值,垃圾自動回收

(2)當調用gc.collect(),垃圾收到回收

(3)程序退出的時候,python解釋器來回收垃圾

5、函數裝飾器的作用?

裝飾器本質上是一個Python函數,它可以讓其他函數在不需要做任何代碼變動的前提下增加額外功能,裝飾器的返回值也是一個函數對象。

它經常用于有切面需求的場景,比如:插入日志、性能測試、事務處理、緩存、權限校驗等場景。

有了裝飾器,我們就可以抽離出大量與函數功能本身無關的雷同代碼并繼續重用。概括的講,裝飾器的作用就是為已經存在的對象添加額外的功能。

6、進程、線程的區別?

(1)定義的不同

進程是系統進行資源分配和調度的一個獨立單位.

線程是進程的一個實體,是CPU調度和分派的基本單位,它是比進程更小的能獨立運行的基本單位.線程自己基本上不擁有系統資源,只擁有一點在運行中必不可少的資源(如程序計數器,一組寄存器和棧),但是它可與同屬一個進程的其他的線程共享進程所擁有的全部資源.

(2)區別

一個程序至少有一個進程,一個進程至少有一個線程.

線程的劃分尺度小于進程(資源比進程少),使得多線程程序的并發性高。

進程在執行過程中擁有獨立的內存單元,而多個線程共享內存,從而極大地提高了程序的運行效率

線線程不能夠獨立執行,必須依存在進程中

(3)優缺點

線程和進程在使用上各有優缺點:線程執行開銷小,但不利于資源的管理和保護;而進程正相反。

7、函數的閉包

閉包就是函數式編程的重要語法結構,提高了代碼可重復實用性。使用特定或特殊的方式,將局部變量(內部函數)引入到全局環境中使用,這就是閉包操作。

8、Python里的拷貝

Copy淺拷貝,只拷貝父元素,deepcopy深拷貝,遞歸拷貝可變對象的所有元素

9、apache和nginx的區別

(1)nginx 相對 apache 的優點:

輕量級,同樣起web 服務,比apache 占用更少的內存及資源

抗并發,nginx 處理請求是異步非阻塞的,支持更多的并發連接,而apache 則是阻塞型的,在高并發下nginx 能保持低資源低消耗高性能

配置簡潔

高度模塊化的設計,編寫模塊相對簡單

社區活躍

(2)apache 相對nginx 的優點:

rewrite ,比nginx 的rewrite 強大

模塊超多,基本想到的都可以找到

少bug ,nginx 的bug 相對較多

超穩定

10、什么是事務?

事務(Transaction)是并發控制的基本單位。所謂事務,它是一個操作序列,這些操作要么都執行,要么都不執行,它是一個不可分割的工作單位。例如,銀行轉帳工作:從一個帳號扣款并使另一個帳號增款,這兩個操作要么都執行,要么都不執行。所以,應該把他們看成一個事務。事務是數據庫維護數據一致性的單位,在每個事務結束時,都能保持數據一致性

事務四大特性

原子性:事務中的全部操作在數據庫中是不可分割的,要么全部完成,要么均不執行

一致性:幾個并行執行的事務,其執行結果必須與按某一順序串行執行的結果相一致

隔離性:事務的執行不受其他事務的干擾,事務執行的中間結果對其他事務必須是透明的

持久性:對于任意已提交事務,系統必須保證該事務對數據庫的改變不被丟失,即使數據庫出現故障

11、主鍵和外鍵的區別?

主鍵在本表中是唯一的、不可唯空的,外鍵可以重復可以唯空;外鍵和另一張表的主鍵關聯,不能創建對應表中不存在的外鍵。

12、在數據庫中查詢語句速度很慢,如何優化?

(1)建索引

(2)減少表之間的關聯

(3)優化sql,盡量讓sql很快定位數據,不要讓sql做全表查詢,應該走索引,把數據 量大的表排在前面

(4)簡化查詢字段,沒用的字段不要,已經對返回結果的控制,盡量返回少量數據

(5)數據庫做好讀寫分離

13、Oracle和Mysql的區別?

1)庫函數不同。

2)Oracle是用表空間來管理的,Mysql不是。

3)顯示當前所有的表、用戶、改變連接用戶、顯示當前連接用戶、執行外部腳本的語句的不同。

4)分頁查詢時候時候不同

5)sql的語法的不同。

14、tcp和udp的區別?

tcp是一種面向連接的、可靠的、基于字節流的傳輸層通信協議。是專門為了在不可靠的互聯網絡上提供一個可靠的端到端字節流而設計的,面向字節流。

udp(用戶數據報協議)是iso參考模型中一種無連接的傳輸層協議,提供面向操作的簡單不可靠的非連接傳輸層服務,面向報文。

它們之間的區別:

1)、tcp是基于連接的,安全性高;udp是基于無連接的,安全性較低;

2)、由于tcp是連接的通信,需要有三次握手、重新確認等連接過程,會有延時,實時性差;同時過程復雜,也使其易于被攻擊;而udp無連接,無建立連接的過程,因而實時性較強,也稍安全;

3)、tcp連接是點到點的電話接通通信;udp支持一對一、一對多、多對一、多對多的廣播通信。

15、對if __ name__ == 'main’的理解?

“ if __ name__ == ‘main’:”

在Python中分為兩類:一種是直接執行,另外一種是作為模塊時才被調用

__ name__ 作為模塊的內置屬性,即".py"文件的調用方式。如果等于“__ main__"就直接執行本文件,如果是別的就是作為模塊被調用

以上就是小千分享的python面試題以及答案。希望能幫到大家!
  
本文來自千鋒教育,轉載請注明出處。

總結

以上是生活随笔為你收集整理的Python开发面试题及部分答案分享!的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。