已經(jīng)學(xué)習(xí)了一段時(shí)間的Python,如果你看過(guò)之前W3Cschool的文章,就知道是時(shí)候該進(jìn)去【項(xiàng)目】階段了。 但是在練手項(xiàng)目的選擇上,還存在疑問(wèn)?不知道要從哪種項(xiàng)目先下手? W3Cschool首先有兩點(diǎn)建議:
接下來(lái)就給大家介紹幾種適合新手的練手項(xiàng)目。 0.算法系列-排序與查找 Python寫(xiě)swap很方便,就一句話(a, b = b, a),于是寫(xiě)基于比較的排序能短小精悍。剛上手一門(mén)新語(yǔ)言練算法最合適不過(guò)了,還能順便刷題,利于找工作。簡(jiǎn)單的練習(xí),讓你受益無(wú)窮。 1.編譯系列 這個(gè)系列的重點(diǎn)就是前面說(shuō)到的簡(jiǎn)化,但是不要指望一口氣寫(xiě)一個(gè)完整的C編譯器,即使只針對(duì)C一個(gè)很小的子集。所以我們需要一步一步來(lái),寫(xiě)一個(gè)計(jì)算器的解釋器是很好的開(kāi)始,再進(jìn)一步可以寫(xiě)一個(gè)極簡(jiǎn)語(yǔ)言的解釋器,譬如brainfuck。 再進(jìn)一步你可以擴(kuò)展已有的計(jì)算器解釋器,譬如加入聲明、賦值與運(yùn)算、循環(huán)、流程控制, 構(gòu)成一個(gè)簡(jiǎn)單的LL(1)語(yǔ)法,然后遞歸下降分析,這就可以搞一個(gè)簡(jiǎn)易同時(shí)又圖靈完備的玩具語(yǔ)言出來(lái)了。 2.分布式系統(tǒng)/計(jì)網(wǎng)系列 這系列的項(xiàng)目,第一步可以從寫(xiě)一個(gè)簡(jiǎn)單的HTTP客戶端開(kāi)始,原因很簡(jiǎn)單,因?yàn)镠TTP大概是最簡(jiǎn)單的應(yīng)用層協(xié)議了。然后可以考慮實(shí)現(xiàn)一個(gè)基本的ssh,你大概每天都會(huì)用ssh,難道不想做一個(gè)自己的簡(jiǎn)易版本嗎? 然后可以考慮分布式系統(tǒng)課上的經(jīng)典作業(yè),譬如寫(xiě)一個(gè)簡(jiǎn)單的RPC??梢詤⒖糐ava的RPC原理以及Google的RPC框架(有Python版)。 3.操作系統(tǒng)系列 操作系統(tǒng)系列,可以嘗試寫(xiě)一個(gè)簡(jiǎn)單的存儲(chǔ)管理的文件系統(tǒng)。第一步的簡(jiǎn)化就是用一個(gè)大的空文件作為磁盤(pán),把對(duì)磁盤(pán)的讀寫(xiě)抽象成對(duì)這個(gè)文件的讀寫(xiě)。基本就是實(shí)現(xiàn)下inode,然后包裝成一個(gè)shell,支持下最基本的命令,新建、追加、讀寫(xiě)、刪除之類(lèi)的操作。這個(gè)練習(xí)最有趣也最有意義的地方在于多級(jí)索引的實(shí)現(xiàn), 4.周邊系列 你也可以試試Jython,IronPython之類(lèi)的,看看和CPython比如何。然后再試試Pypy,必然是一開(kāi)始很高興,最后發(fā)現(xiàn)各種常見(jiàn)庫(kù)不支持,最后還是轉(zhuǎn)回CPython。 做實(shí)驗(yàn)的話用IPython把Python函數(shù)當(dāng)命令跑很方便。 |
|
來(lái)自: 習(xí)悟齋 > 《編程開(kāi)發(fā)》