PLT 板


LINE

看板 PLT  RSS
※ 引述《macbuntu (邀怪)》之銘言: : Scala 的 compiler 就會把上面紅色的地方標成錯誤而不會 compile 成功, : 原因是 Scala 會根據型別出現的位置來決定該位置所能允許的 variant 種類, : 所以像 function argument type 是 contravariant 而 return type 是 covariant : 這類的規則直接定義成語言的一部分, 再將 programmer 宣告的 +/- variant 方式 : 跟這些位置作比對, 符合才放行, 從根本上解決了 variant 跟 OO 的衝突問題. : 覺得這種方法挺漂亮的, 其實可以加到 Java 的語法裡又不會造成衝突. : 以現在的 Java 來說: : interface A<T> { : public T get(); : } : class B { : static void func(A<Object> a) { .... } : } : A<String> obj = /* new something */; : B.func(obj); // compile time error, A<String> is not an A<Object> : 這裡 Java compiler 不允許, 但是仔細看 A<T> 的 T 其實只用在 return type, : 把 A<String> 當作 A<Object> 使用一點問題也沒有. 如果把 Scala 的設計加進去: : interface A<+T> { : public T get(); // OK : } : interface B<+T> { : public T get(); // OK : public void set(T t); // compile time error : } : interface C<-T> { : public void set(T t); // OK : } : interface D<-T> { : public T get(); // compile time error : public void set(T t); // OK : } : interface E<T> { : public T get(); // OK : public void set(T t); // OK : } : 靠 compiler 來檢查所有定義為 +T (covariant) 的型別只能用在 return type, : 而所有 -T (contravariant) 的型別只能用在 arguments type, : 如果同時用在兩個地方, 或是 public field type, 就一定得指定成 T (invariant), : 這樣就皆大歡喜了. : [略] : 印象中現在 Java 1.5 generics type 的設計就是出自於設計 Scala 的同一人? : 不知他當時沒把這個放入 Java 中是有什麼原因? 還是當初還沒有這個點子... 我沒有什麼 scala programming 的經驗,我想請教 scala 中 generic type 定義時使用的 Variance Annotations 實際上能帶來什麼好處? 你覺得如果把這個 feature 加進 Java PL 是個好事,可否請你說說這個 feature 在實際 programming 上帶來最大的好處是什麼?你一定有你自己的想法,你才會 認為如果 Java 也加入這個 feature 是好的。 我認為 generic type 大部分會是上述的 interface E 這種型態居多,這種類型 的 generic type 在 scala 裡只能定義為 non-variant subtyping,那麼用上此 feature 的機會不多。 第二,我認為不應該是由 generic type 來決定 subtyping variance,而是由 client code 來決定。 假設今天有一個如下的 interface: // Java code public interface Variable<T> { public T getValue(); public void setValue(T val); } 這個 class 以 scala 來實做也只能定義成 non-variant subtyping。 今天有一個 client code 需要使用到 Variable instance,他需要做的是只是 把 Variable value 輸出到 stdout,那麼他只需要 Variable value 至少是個 Object 即可。 // Java code public class Interpreter { public void dump(Variable<? extends Object> var) { System.out.println(var.getValue()); } } 這種情況下,client 只使用到 Variable - getValue method,所以可以容許 var 變數是 co-variant subtyping;如果有另一個功能需要使用到的只有 Variable - setValue method,那麼他可以自行決定容許 contra-variant subtyping。比如現在要實做一個 assign 某個 String value 成 Variable value, 若直接寫成這樣: // Java code public void assign(Variable<String> var, String val) { var.setValue(val); } 就會發生如同你描述的現象:無法將 String value assign 給 Variable<Object>。 但實際上是設計 assign 操作的人應該要想到,String value 應該可以 assign 給 type parameter lower bound 在 String 的 Variable instance,而寫成 : // Java code public void assign(Variable<? super String> var, String val) { var.setValue(val); } 或是更一般化: public <V> void assign(Variable<? super V> var, V val) { var.setValue(val); } * 這在 scala 中也是要採用類似的作法 如果一個 Java programmer 沒有對 wildcard/bounded wildcard 有足夠的觀念, 那麼即使把 scala Variance Annotations 加入 Java PL,對他們不會帶來多大的 好處(因為 Variable 這種類型的 generic type 佔大多數)。 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 218.173.129.21







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP