1. 程式人生 > >據說這篇總結覆蓋了一般Python開發面試中可能會問到的大部分問題

據說這篇總結覆蓋了一般Python開發面試中可能會問到的大部分問題

點選上方“程式人生”,選擇“置頂公眾號”

第一時間關注程式猿(媛)身邊的故事

640?wx_fmt=png&wxfrom=5&wx_lazy=1

原文標題:一名python web後端開發工程師的面試總結

先介紹下我的情況

通訊背景,工作一年多不到兩年。之前一直在做C++的MFC軟體介面開發工作。公司為某不景氣的國企研究所。(喏,我的工作經驗很水:1是方向不對;2是行業有偏差)。然後目前是在尋找python後端開發這一塊的工作,使用的框架為django;之前一直通過CSDN以及其他幾家技術部落格/論壇吸收大家的經驗,在感激之餘,也想輸出點什麼,造福大家,因此就有了這篇水文,希望大家能夠多多吸取我的經驗教訓,早日找到一份自己滿意的工作!

面試的幾家:北京的兩家創業公司,規模均在40-50人之間;果殼(止步於電話面,拉鉤投的);知乎(止步於電話面,論壇發帖後的內推);愛奇藝(拉鉤上投的);杭州的網易(同學內推)。

0?wx_fmt=jpeg

面試這一輪下來,最大的感受就一個:平時一定要堅持每天都碼點程式碼。就算再爛的專案,也要堅持上傳github……真的,只要你能堅持一週有5天以上都能持續上傳Git,半年下來,面試官絕對對你刮目相看。

其他感受:不同的公司著重點都不一樣,不過真的就如這篇博文(http://blog.csdn.net/yueguanghaidao/article/details/49638261)的博主所說,木桶原理,哪塊都不能少。我就是因為平時只關注做自己的小部落格系統,而沒做其他的部分,導致愛奇藝倒在了手寫程式碼上面……哎,憂傷……平時多刷刷leetcode,看看劍指offer/面試金典,都是套路啊~~

面試這幾家公司所遇到的面試/筆試題,目前還能記住的如下。雖然可能絕大部分都是基礎,但希望大家不要只是看看就過去了

,最好還是假裝你被問到這個問題,你來把答案說出來或寫出來:(不按公司分了)

python語法以及其他基礎部分

可變與不可變型別; 
淺拷貝與深拷貝的實現方式、區別;deepcopy如果你來設計,如何實現; 
__new__() 與 __init__()的區別; 
你知道幾種設計模式; 
編碼和解碼你瞭解過麼; 
列表推導list comprehension和生成器的優劣; 
什麼是裝飾器;如果想在函式之後進行裝飾,應該怎麼做; 
手寫個使用裝飾器實現的單例模式; 
使用裝飾器的單例和使用其他方法的單例,在後續使用中,有何區別; 
手寫:正則郵箱地址; 
介紹下垃圾回收:引用計數/分代回收/孤立引用環; 
多程序與多執行緒的區別;CPU密集型適合用什麼; 
程序通訊的方式有幾種; 
介紹下協程,為何比執行緒還快; 
range和xrange的區別(他妹的我學的py3…); 
由於我有C/C++背景,因此要求用C來手寫:將IP地址字串(比如“172.0.0.1”)轉為32位二進位制數的函式。

演算法排序部分

手寫快排;堆排;幾種常用排序的演算法複雜度是多少;快排平均複雜度多少,最壞情況如何優化; 
手寫:已知一個長度n的無序列表,元素均是數字,要求把所有間隔為d的組合找出來,你寫的解法演算法複雜度多少; 
手寫:一個列表A=[A1,A2,…,An],要求把列表中所有的組合情況打印出來; 
手寫:用一行python寫出1+2+3+…+10**8 ; 
手寫python:用遞迴的方式判斷字串是否為迴文; 
單向連結串列長度未知,如何判斷其中是否有環; 
單向連結串列如何使用快速排序演算法進行排序; 
手寫:一個長度n的無序數字元素列表,如何求中位數,如何儘快的估算中位數,你的演算法複雜度是多少; 
如何遍歷一個內部未知的資料夾(兩種樹的優先遍歷方式)

網路基礎部分

TCP/IP分別在模型的哪一層; 
socket長連線是什麼意思; 
select和epoll你瞭解麼,區別在哪; 
TCP UDP區別;三次握手四次揮手講一下; 
TIME_WAIT過多是因為什麼; 
http一次連線的全過程:你來說下從使用者發起request——到使用者接收到response; 
http連線方式。get和post的區別,你還了解其他的方式麼; 
restful你知道麼; 
狀態碼你知道多少,比如200/403/404/504等等;

資料庫部分

MySQL鎖有幾種;死鎖是怎麼產生的; 
為何,以及如何分割槽、分表; 
MySQL的char varchar text的區別; 
瞭解join麼,有幾種,有何區別,A LEFT JOIN B,查詢的結果中,B沒有的那部分是如何顯示的(NULL); 
索引型別有幾種,BTree索引和hash索引的區別(我沒答上來這倆在磁碟結構上的區別); 
手寫:如何對查詢命令進行優化; 
NoSQL瞭解麼,和關係資料庫的區別;redis有幾種常用儲存型別;

Linux部分

講一下你常用的Linux/git命令和作用; 
檢視當前程序是用什麼命令,除了檔案相關的操作外,你平時還有什麼操作命令; 
(因為我本人Linux本身就很水,只會基本的操作,所以這部分面試官也基本沒怎麼問。。反正問了就大眼瞪小眼唄)

0?wx_fmt=jpeg

django專案部分

都是讓簡單的介紹下你在公司的專案,不管是不是後端相關的,主要是要體現出你幹了什麼; 
你在專案中遇到最難的部分是什麼,你是怎麼解決的; 
你看過django的admin原始碼麼;看過flask的原始碼麼;你如何理解開源; 
MVC / MTV; 
快取怎麼用; 
中介軟體是幹嘛的; 
CSRF是什麼,django是如何避免的;XSS呢; 
如果你來設計login,簡單的說一下思路; 
session和cookie的聯絡與區別;session為什麼說是安全的; 
uWSGI和Nginx的作用; 
(我發現基本不問django實現細節相關的東西。。或者問也問的很少,哎,之前準備的方向完全錯了)

0?wx_fmt=jpeg

洋洋灑灑寫了一個小時,發現還是有很多細節問題都已經忘了。。哎,自己的筆記做的還是不行。不過這些問題如果你能都答上來,起碼我覺得你應該可以去試試面試初級web後端了,good luck!

後記:發現一個整理的特別棒的github倉庫,比我寫的強多了。共享給大家~:https://github.com/taizilongxu/interview_python

THE END -

你有哪些面試經驗?

歡迎投稿分享

徵稿要求:

①稿件字數以800~1500字左右為宜,多於2000字的文章在手機上閱讀起來比較麻煩,少於800字的文章看起來不過癮;

②你有自己拍的適合做文章插圖的照片也可一併附上~如果不方便,程式和小七也會幫你配圖~

0?wx_fmt=gif

加程式人生編輯們的微信,備註#投稿#:

程式 微信ID:druidlost  

小七 微信ID:duoshangshuang  

我們在這裡期待你的故事!

點選圖片get往期內容

0?wx_fmt=png

0?wx_fmt=png

0?wx_fmt=png

0?wx_fmt=gif