看板 PLT 關於我們 聯絡資訊
※ 引述《godfat (godfat 真常)》之銘言: : ※ 引述《brianhsu (墳墓)》之銘言: : : 在 Scala 裡,我們也是自己定義了 lat 的 getter / setter,眼尖的朋 : : 友可能發現了原來成員變數的 lat 現在變成了 mLat,這是 Scala 本身的 : : 限制,因為 Scala 自己就會幫我們產生一組 getter / setter。 : 這邊說 Scala 自己產生 getter/setter 是指? : 我還沒把 Scala 看完,不過不記得有這樣的機制在。 : 在範例程式裡,看起來像是原本 lat 是指到一個 var, : 而後來的修改則改為一個 method. 然而因為 method 的 () : 可以省略,所以對 client code 來說是長得一樣。 : 我猜會需要重新 compile? 沒有驗證。 先離題,我適過 Haskell 了,不過結論是我不喜歡 pure functional 的語言。 有的時候 functional 反而讓程式很難懂或很難寫。 我自己覺得是人要玩程式語言,而不是被程式語言玩啊。>_< Scala 裡的機制是比較特別的,他提供了幾種情況給你選: class Name (x: Int) ==> x 是單純的 local val 變數 class Name (val x:Int) ==> x 有 getter class Name (var x:Int) ==> x 有 getter / setter Scala 裡的 field 與 method 確實在同一個命名空間沒錯,不 過實際上用到的都是 method,只是被 compiler 幹掉了而已。 在這邊 Scala 遵守的是滿傳統的 uniform aceess princple, 所以 client 端也不用重新 compile。 例如這個 Class class Test { val onlyGetter = 10 var getterSetter = 20 } 實際上會被翻(用 scalac -print 可以看,我有簡化)成: class Test extends java.lang.Object with ScalaObject { private[this] val onlyGetter: Int = 10; <stable> <accessor> def onlyGetter(): Int = Test.this.onlyGetter; private[this] var getterSetter: Int = 20; <accessor> def getterSetter(): Int = Test.this.getterSetter; <accessor> def getterSetter_=(x$1: Int): Unit = Test.this.getterSetter = x$1 } private[this] 的意思和 ruby 裡的 private 一樣,只有自己的 instance 看得到。 所以實際上外界在用的都是 method。 不過因為命名空間的問題,實際上不能照 compiler 翻出來的那樣寫。 這個在這邊有: http://programming-scala.labs.oreilly.com/ch06.html#UniformAccessPrinciple -- ~ 白馬帶著她一步步地回到中原。白馬已經老了,只能慢慢地走, 'v' Brian Hsu 但終是能回到中原的。江南有楊柳、桃花,有燕子、金魚…… // \\ ( 墳 墓 ) /( )\ 但這個美麗的姑娘就像古高昌國人那樣固執。 【白馬嘯西風】 ^`~'^ http://bone.twbbs.org.tw/blog 『那都是很好很好的,可我偏不喜歡。』 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 59.120.199.114 ※ 編輯: brianhsu 來自: 59.120.199.114 (01/08 18:24)
godfat:oh, i see... 01/08 19:00
godfat:thanks! 01/08 19:10