Ruby中的集合編寫指南
傾向數(shù)組及哈希的字面表示法(除非你需要傳遞參數(shù)到它們的構(gòu)造函數(shù)中)。
# bad arr = Array.new hash = Hash.new # good arr = [] hash = {}
當(dāng)你需要元素為單詞(沒有空格和特殊符號)的數(shù)組的時(shí)候總是使用 %w 的方式來定義字符串?dāng)?shù)組。應(yīng)用這條規(guī)則僅僅在兩個(gè)或多個(gè)數(shù)組。
# bad STATES = ['draft', 'open', 'closed'] # good STATES = %w(draft open closed)
當(dāng)你需要一個(gè)符號的數(shù)組(并且不需要保持 Ruby 1.9 兼容性)時(shí),使用 %i。僅當(dāng)數(shù)組只有兩個(gè)及以上元素時(shí)才應(yīng)用這個(gè)規(guī)則。
# bad STATES = [:draft, :open, :closed] # good STATES = %i(draft open closed)
避免在 Array 或者 Hash 的最后一項(xiàng)后面出現(xiàn)逗號,特別是當(dāng)這些條目不在一行。
# bad - easier to move/add/remove items, but still not preferred VALUES = [ 1001, 2020, 3333, ] # bad VALUES = [1001, 2020, 3333, ] # good VALUES = [1001, 2020, 3333]
避免在數(shù)組中創(chuàng)造巨大的間隔。
arr = [] arr[100] = 1 # now you have an array with lots of nils
當(dāng)訪問一個(gè)數(shù)組的第一個(gè)或者最后一個(gè)元素,傾向使用 first 或 last 而不是 [0] 或 [-1]。
如果要確保元素唯一, 則使用 Set 代替 Array .Set 更適合于無順序的, 并且元素唯一的集合, 集合具有類似于數(shù)組一致性操作以及哈希的快速查找.
盡可能使用符號代替字符串作為哈希鍵.
# bad hash = { 'one' => 1, 'two' => 2, 'three' => 3 } # good hash = { one: 1, two: 2, three: 3 }
避免使用易變對象作為哈希鍵。
優(yōu)先使用 1.9 的新哈希語法當(dāng)你的哈希鍵是符號。
# bad hash = { :one => 1, :two => 2, :three => 3 } # good hash = { one: 1, two: 2, three: 3 }
在相同的 hash 字面量中不要混合 Ruby 1.9 hash 語法和箭頭形式的 hash。當(dāng)你
得到的 keys 不是符號的時(shí)候轉(zhuǎn)換為箭頭形式的語法。
# bad { a: 1, 'b' => 2 } # good { :a => 1, 'b' => 2 }
用 Hash#key? 不用 Hash#has_key? 以及用 Hash#value?, 不用 Hash#has_value? Matz 提到過 長的形式在考慮被棄用。
# bad hash.has_key?(:test) hash.has_value?(value) # good hash.key?(:test) hash.value?(value)
在處理應(yīng)該存在的哈希鍵時(shí),使用 fetch。
heroes = { batman: 'Bruce Wayne', superman: 'Clark Kent' } # bad - if we make a mistake we might not spot it right away heroes[:batman] # => "Bruce Wayne" heroes[:supermann] # => nil # good - fetch raises a KeyError making the problem obvious heroes.fetch(:supermann)
在使用 fetch 時(shí),使用第二個(gè)參數(shù)設(shè)置默認(rèn)值而不是使用自定義的邏輯。
batman = { name: 'Bruce Wayne', is_evil: false } # bad - if we just use || operator with falsy value we won't get the expected result batman[:is_evil] || true # => true # good - fetch work correctly with falsy values batman.fetch(:is_evil, true) # => false
盡量用 fetch 加區(qū)塊而不是直接設(shè)定默認(rèn)值。
batman = { name: 'Bruce Wayne' } # bad - if we use the default value, we eager evaluate it # so it can slow the program down if done multiple times batman.fetch(:powers, get_batman_powers) # get_batman_powers is an expensive call # good - blocks are lazy evaluated, so only triggered in case of KeyError exception batman.fetch(:powers) { get_batman_powers }
當(dāng)你需要從一個(gè) hash 連續(xù)的取回一系列的值的時(shí)候使用 Hash#values_at。
# bad email = data['email'] nickname = data['nickname'] # good email, username = data.values_at('email', 'nickname')
記住, 在 Ruby1.9 中, 哈希的表現(xiàn)不再是無序的. (譯者注: Ruby1.9 將會記住元素插入的序列)
當(dāng)遍歷一個(gè)集合的同時(shí), 不要修改這個(gè)集合。
相關(guān)文章
ruby元編程之method_missing的一個(gè)使用細(xì)節(jié)
這篇文章主要介紹了ruby元編程之method_missing的一個(gè)使用細(xì)節(jié),本文介紹在使用method_missing時(shí)造成死循環(huán)的一個(gè)現(xiàn)象,需要的朋友可以參考下2015-05-05Ruby on Rails中Rack中間件的基礎(chǔ)學(xué)習(xí)教程
Rack是一個(gè)連接Ruby程序與服務(wù)器程序之間的中間件,甚至可以說Rails也是在Rack的基礎(chǔ)上建立起來的,這里我們就來為大家?guī)鞷uby on Rails中Rack中間件的基礎(chǔ)學(xué)習(xí)教程2016-06-06Ruby on Rails遷移時(shí)的一些注意事項(xiàng)
這篇文章主要介紹了Ruby on Rails遷移時(shí)的一些注意事項(xiàng),包括建議的使用change方法取代up與down方法等細(xì)節(jié),需要的朋友可以參考下2015-08-08實(shí)例講解Ruby使用設(shè)計(jì)模式中的裝飾器模式的方法
這篇文章主要介紹了Ruby使用設(shè)計(jì)模式中的裝飾器模式的實(shí)例, 裝飾模式能夠?qū)崿F(xiàn)動態(tài)的為對象添加功能,需要的朋友可以參考下2016-03-03