如何學習Ruby

提示:本文是學習方法論,不喜勿看。

我是從06年底開始關注Ruby的,07年的時候投入到了Ruby的開發中,並持續到今天。我從畢業到現在,除了Ruby還使用過VB、Java、JavaScript, 大學裏也學過C/彙編,因爲我是學電子專業的,偏硬件一些,所以沒有很好的學習算法相關的內容,所以本文也不會涉及算法學習的內容, 這是我作爲一個程序員的硬傷,當然我還在學習算法的路上,並未放棄它。

和大多數的Rubyist一樣,我也是從學習Rails開始去了解Ruby的,在學習Rails之前,我正在使用JavaEE的SSH框架(struts+spring+hibernate), 當時也算是Java入門的階段,並沒有做的多深,各種XML配置,搞的我眼花繚亂,對Java頓時有點絕望:是不是我以後的編程生涯就和XML打交道了呢? Rails的約定大於配置,DRY(Don't repeat yourself)等概念,深深的吸引了我,使用Rails,再也不用去煩那一大堆XML配置了,我只要專心寫我的Ruby代碼就可以了,這纔是快樂的程序員嘛。呵呵,不知道有多少人和我的經歷類似呢? 我想應該也有不少人吧。

說到Rubyist, 我曾經也不理解,爲什麼叫Rubyist,而不叫Rubyer或者其他? 後來我才明白了, Rubyist,有點Artist的意味。Ruby語言算是編程領域裏最具藝術氣息的了,所以我們把Ruby程序員叫做Rubyist。但實際上,很多人離真正的Rubyist還很遠,包括我自己啦。


懵懂:

正是經歷過這個階段,所以我很瞭解現在的初學者的心情:「不是15分鐘開發一個blog嗎? Rails很好學,很好用,很好玩,我要快速精通它」。 很多Rubyist的入門書就是「Agile web development with Rails」和 「Programming Ruby」, 基本上,如果通讀這兩本書並練習以後,基本就可以上手了。當然現在也涌現出很多學習Rails的優秀書籍,比如 「Ruby on Rails Tutorial」和最近kickstarter上面衆籌的「Learn Ruby on Rails」,還有官方的「Ruby on Rails Guides」, 在我開始學習的時候,官方的文檔可沒有這麼好。

有這麼豐富的資料,我們對於Rails的入門,基本沒有什麼困難了。 但是你有沒有發現,你已經陷入了一個巨大的細節裏面去了。我所說的這個巨大的細節,就是指Rails。

我們最初學習Ruby的目標是掌握Rails, 所以潛意識裏,Ruby的學習,放到了第二位, 而Rails成爲了第一位的學習目標。在你通讀各種參考書入門之後,也許你可以開發一個簡單的web站點,也可以把自己的Rails技能運用於一般的工作中,但是你會發現,你終會達到一個學習的瓶頸。 Rails社區的一個好處,就是有很多的Gem,各種各有的Gem讓你快速的開發,但是你真正的瞭解這些Gem嗎?開發,並不是一個簡單的功能堆砌。

當你聽說現在流行Cucumber,所以對自己該選用Cucumber或者是Rspec感到迷惑了起來,MiniTest的崛起,又讓你感到更迷惑了,我該用哪個?
當你聽說Rails4默認了線程安全,那麼你是否知道什麼是線程安全?Rails3不也是線程安全的嗎?默認的意義何在?
當你聽說sidekiq比resque更省內存的時候,就馬上想去嘗試改用sidekiq,有沒有想過,爲什麼?sidekiq比resque寫的好?
。。。
等等

這個時候,我們僅停在了使用階段!因爲你已經陷入了Rails的細節裏,你忽視了Ruby。

所以,此時,你僅僅是個Ruby碼農,離Rubyist,還差很遠。


深入

如你所見,你所用到的一切,都是Ruby構建起來的:Rails、Sinatra、Cucumber、RSpec、Sidekiq、Resque等。
Ruby + Web開發知識 + 架構思想 -> Rails/Sinatra
Ruby + TDD/BDD等敏捷實踐 -> Cucumber/Rspec
Ruby + 多線程/多進程併發 -> Sidekiq/Resque
Ruby + Actor併發模型 -> Celluloid
Ruby + Socket+Reactor -> eventmachine/Goliath
...
等等等

所以,你要想深入掌握上述各種工具,你就需要系統的去學習Ruby,並且在學習Ruby的過程中,去學習相關的領域知識,這是一個良性的循環過程。

Ruby是一個面向對象並同時兼有函數式編程特性的神奇語言,所以在你隨着Ruby的深入學習,你同時可以深入學習面向對象和函數式編程兩種範式的特性。

所以,當我們說深入學習Ruby的時候,不是在說Ruby的語法該如何用,而是在說:

1 Ruby背後的設計哲學及其底層實現。
2 Ruby與系統(包括其他領域,比如web)的交互
3 Ruby如何根據它的面向對象和函數式編程特性、及其元編程能力去構建漂亮的DSL

達到這個階段,你可能脫離了Ruby碼農的層次,達到一個新的境界了,離Rubyist已經很接近了。


哲學

如果說算法是一個合格的程序員必須掌握的,那麼哲學,也是一個合格的程序員必須要領悟的。

我不是一個哲學大師,請不要誤會。

哲學是我們學習和解決問題的靈魂,我只在這裏分享幾條我用到的哲學經驗:

1. 重是輕的根本,靜是躁的主宰.

Ruby,只有基礎紮實了,才能用的靈活。
當我們碰到問題的時候,着急沒用,靜下心來思考,順藤摸瓜,找出問題。
當我們學習的時候,不要急於求成,靜下心來學習,慢就是快。

2. 存在即合理。

對於這句話,我的理解就是, 當程序出現了詭異的bug,或者,當你的項目在你機器上能用,而到服務器上不能用的時候,你應該想想,這個問題並不詭異, 程序是按你的指令執行的,肯定是你哪裏出問題了,而且可能是個嚴重的問題!請認真對待這個問題!
學習的時候,碰到一個概念,應該多想想這個概念產生的合理性,比如TDD/BDD, 有了TDD爲什麼還會有BDD?

3. 哲學經典三問: 你從哪裏來?你是誰? 你要到哪裏去?

當我們學習新技術的時候,我們就該問了:
這技術是基於什麼情形產生的,或者是這技術是爲了解決什麼問題而出現的? (你從哪裏來?)
這技術是如何實現的?這項技術如何去使用? (你是誰?)
這技術要解決的問題是永久性的嗎?未來的發展會如何?和這種技術類似的有哪些技術,它們的發展如何?(你要到哪裏去?)


總結:

本文,與其說是「如何學習Ruby」,不如就說是「如何學習」,因爲以上方法論,適用於你學習任何東西。


P.S 附帶「誘人的Ruby」課程規劃簡要:
rubyroadmap.pngrubyroadmap.png


最後,

希望大家關注微信公衆帳號:RubyStudy,與我討論任何問題,包括對本文你自己的見解。
屏幕快照 2013-10-30 下午7.02.17.png


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章