[Ruby] 8th word

不知道自己還會持續寫多久,雖然自己內心有千百個不願意學Ruby(就是單純不想而已,那個Fu不對),不過我還是會繼續加油的。就當作翻譯書吧XD…

現在要再延續上次講的equality。如果還有點印象的話,應該是談到「==」operator吧,既然有正就有反,當然有「!= (Not equal)」啦,書上說,只要原先的「==」operator有被定義的話,那麼這個operator就是把它的值做invert的動作,true←→false那個值互換,所以這在Ruby1.9之前,Ruby會自動把這個operator給你使用for free!!(前提是你有定義好其「==」的動作),而在Ruby1.9之後,類別可以自己定義自己的「!=」operator來達到自己想要的效果。

有時候很該死的就是會出現很多相似的Method,這真的是很煩,因為要了解他們之間那極度細微的差異,不過也不能怪誰,因為那是別人規範好的= =…

3.8.5.3 The eql? method

「eql?」是一個不做type conversion的Method,來看一下他和「==」的差別:

http://gist.github.com/293535.js?file=gistfile1.rb

原來如此呀,恩恩…

3.8.5.5 The =~ operator

這就酷了,看到這個就想起RE的日子,YES,這就是用在做Pattern matching的operator,被定義在String和Regexp的類別下,不過書上也說了這其實和equality沒有什麼太大的關係,只不是有個「=」就把它放在這邊XD,所以只要記得這是拿來做Regular Expression用的就好了,來個小例子,其他深入的後面再談:

http://gist.github.com/293540.js?file=gistfile1.rb

3.8.6 Object Order

這邊有一個好玩的東西叫做物件的排序,哇靠這是啥?我原本也不知道它想幹嘛,不過看一下書後就了解許多了。通常每個類別都會定義「==」來了解equality,而有些類別,還會定義「排序」。什麼意思咧,假設有BC兩個都是A類別的實體,我們可以定義說它那兩個實體是「相等」,還是B比C小。原本我看到這都傻眼了,這是什麼鳥,完全看不懂呀,但是它下面提到了「Number」這個類別就是一個很明顯的例子,整個一下子就通了!!!

怎麼說呢?因為萬物皆OO的Ruby,其實「數字(123)」個別都是一個物件呀,而我們的數字可以比大小,就代表在某些類別下是可以比大小的,因此在某一方面來說就是做了一個排序的動作,這樣子是不是就很好了解了!?

所以如果我們要在Ruby做「排序」這件事情的話,就要使用「」這個operator。「AB」代表說,如果AB就會回傳1。來看個例子:

http://gist.github.com/293542.js?file=gistfile1.rb

但是因為這個Operator不太直覺,所以類別都會再include「Comparable」模組來做混入(mixin),而它定義了這幾個operator如下:

http://gist.github.com/293543.js?file=gistfile1.rb

下面這個是我在說明內找到的一個還蠻容易看懂的範例,可以參考一下他是怎麼做到的:

http://gist.github.com/293545.js?file=gistfile1.rb

另外有一點雖然前面提過了,但是還是要注意一下,那就是Comparable模組沒有定義「!=」,不過Ruby會自動幫我們先做「==」的動作再把結果Invert,所以就免擔心啦。

最後要是書上提到的一個NaN的情況(0/0的時候),而比較的結果就請看一下Code啦:

http://gist.github.com/293547.js?file=gistfile1.rb

這邊來了一個問題,為什麼「nan.euqal?(nan)」的結果是True??沒錯,因為他們兩個都是指向同一個object,所以結果為真,這邊要注意一下!!

BTW,通常「==」會被覆寫掉,但是「Aobj.equal?(Bobj)」是不應該在子類別被覆寫的,這是說明上面特別強調的一點,還要再注意一下!!

就是這樣,這篇就先到這啦,我要來去玩了XD~

發表迴響

在下方填入你的資料或按右方圖示以社群網站登入:

WordPress.com Logo

您的留言將使用 WordPress.com 帳號。 登出 / 變更 )

Twitter picture

您的留言將使用 Twitter 帳號。 登出 / 變更 )

Facebook照片

您的留言將使用 Facebook 帳號。 登出 / 變更 )

Google+ photo

您的留言將使用 Google+ 帳號。 登出 / 變更 )

連結到 %s