分享Ruby應用技巧
學習一項編程語言最重要的就是實踐操作,只有在實踐中不斷的積累經驗才能充分掌握我們所學到的書本知識。Ruby語言的學習也不例外。下面就介紹幾種Ruby應用技巧,供大家參考。#t#
Ruby應用技巧之語句定界符
有些語言需要一定類型的標點,一般會是分號(;)來結束程序的每一語句.Ruby卻采用了shell里的sh和csh的方便做法.一行中的多個語句由分號分開,但在行尾分號卻并不需要;一個換行被看作一個分號.如果行以反斜杠(\)結束,隨后的換行將忽略;這就允許你的單個邏輯行可以跨越數行.
Ruby應用技巧之注釋
為什么寫注釋?雖然良好的代碼可自成文檔,但那種自以為別人能看懂并按你的方式很快去理解的想法是錯誤的.除此之外,你自己在離開數天后也會是另一個人;一段時間后我們忘了我們還未修補或增強程序中的哪些部分,你會說,我知道我寫了這個的,但我究竟寫的是些什么?
一些有經驗的程序員會相當正確地指出,矛盾的和過期的注釋比沒有強.當然,有了注釋并不意味著代碼的可讀性;如果你的代碼不清晰,它也許是多蟲的.當你學習Ruby的時候,你會發現自己需要更多的注釋;然后當你可以通過更簡單,優雅,可讀的代碼來表達思想時,它們就會減少.
Ruby遵從一些普遍的書寫習慣,用井號(#)表示注釋的開始.跟在#號后面直到#號這行結束為止的代碼都將被解釋器忽略.
同時,為了方便寫大塊的注釋, Ruby解釋器省略以"=begin"和"=end"開始的行中間的一切.
- #!/usr/bin/env ruby
- =begin
- ****************************************
- This is a comment block,
something you write for
the benefit of- human readers (including
yourself). The interpreter ignores it.- There is no need for a
'#' at the start of every line.- ***************************************
- =end
Ruby應用技巧之組織你的代碼
Ruby讀到什么就處理什么.沒有編譯處理;如果有什么還沒讀到,就被簡單地認為未定義.
- # this results in an
"undefined method" error:- print successor(3),"\n"
- def successor(x)
- x + 1
- end
這并不是像一開始認為的那樣,強迫你以從上至下的方式組織你的代碼.只要你確保其在調用前將被定義,當解釋器遇到一個方法定義時,它能安全地接受暫未定義的引用.
- # Conversion of fahrenheit
to celsius, broken- # down into two steps.
- def f_to_c(f)
- scale(f - 32.0) # This is a
forward reference, but it's okay.- end
- def scale(x)
- x * 5.0 / 9.0
- end
- printf "%.1f is a comfortable
temperature.\n", f_to_c(72.3)
所以,一方面看起來比使用Perl或Java要稍稍不方便一些,但卻沒有寫C那么嚴格(要求你永遠維持所指的部分排序).將***層的代碼放在源文件的***總是可行的.即使這樣也比看見時要好的多.一個明智而無痛苦的好辦法是將main定義在文件頂端,再在底端調用它.
- #!/usr/bin/env ruby
- def main
- # Express the top level logic here...
- end
- # ... put support code here,
organized as you see fit ...- main # ... and start execution here.
Ruby也提供了將復雜程序分割為可讀,可重用,邏輯相關的大塊的工具.我們已看到用 include 來訪問模塊.你將發現 load 和 require 也很有用.load的作用類似于文件的復制加粘貼(和C的#include處理器指令相似).require更復雜,僅在需要時才加載,而且最多加載一次.load和require還有其它一些區別;在語言手冊,FAQ中可找到更多信息.
就是這些了...
這個Ruby應用技巧教程應該足夠幫助你開始編寫Ruby程序了.隨著問題的深入,你可以深入參考手冊.FAQ和庫參考也是很重要的資源.