在練手項目的選擇上,還存在疑問?不知道要從哪種項目先下手?
首先有兩點建議:
最好不要寫太應用的程序練手,要思考什么更像是知識,老只會寫寫爬蟲是無用的,但是完全不寫也不行。
對于練手的程序,要注意簡化和抽象,但是如果簡化不得當的話,很容易看幾篇教程就被懶得下手了。
接下來就給大家介紹幾種適合新手的練手項目。
0.算法系列-排序與查找
Python寫swap很方便,就一句話(a, b = b, a),于是寫基于比較的排序能短小精悍。剛上手一門新語言練算法最合適不過了,還能順便刷題,利于找工作。簡單的練習,讓你受益無窮。
1.編譯系列
這個系列的重點就是前面說到的簡化,但是不要指望一口氣寫一個完整的C編譯器,即使只針對C一個很小的子集。所以我們需要一步一步來,寫一個計算器的解釋器是很好的開始,再進一步可以寫一個極簡語言的解釋器,譬如brain***。
再進一步你可以擴展已有的計算器解釋器,譬如加入聲明、賦值與運算、循環、流程控制, 構成一個簡單的LL(1)語法,然后遞歸下降分析,這就可以搞一個簡易同時又圖靈完備的玩具語言出來了。
2.分布式系統/計網系列
這系列的項目,第一步可以從寫一個簡單的HTTP客戶端開始,原因很簡單,因為HTTP大概是最簡單的應用層協議了。然后可以考慮實現一個基本的ssh,你大概每天都會用ssh,難道不想做一個自己的簡易版本嗎?
然后可以考慮分布式系統課上的經典作業,譬如寫一個簡單的RPC。可以參考Java的RPC原理以及Google的RPC框架(有Python版)。
3.操作系統系列
操作系統系列,可以嘗試寫一個簡單的存儲管理的文件系統。第一步的簡化就是用一個大的空文件作為磁盤,把對磁盤的讀寫抽象成對這個文件的讀寫?;揪褪菍崿F下inode,然后包裝成一個shell,支持下最基本的命令,新建、追加、讀寫、刪除之類的操作。這個練習最有趣也最有意義的地方在于多級索引的實現,
4.周邊系列
你也可以試試Jython,IronPython之類的,看看和CPython比如何。然后再試試Pypy,必然是一開始很高興,最后發現各種常見庫不支持,最后還是轉回CPython。
做實驗的話用IPython把Python函數當命令跑很方便。
評論
查看更多