PLT 板


LINE

看板 PLT  RSS
看到 godfat 大大在 Java 版提到 Scala 的 Variant 方式, 覺得很有趣, 上網找了 Scala 的資料看了一下, 發現 Scala 的 type variance 選擇還真多, 三種 variance 方法都允許, 而且是可以直接應用在 type parameter 上面. 但是仔細想想, 就開始懷疑某些 variance 在實務上的實用性, 甚至有時候會干擾原先 OO 的語意? 譬如從 Covariant 開始, 如果定義 List[+T], 則只要 A 是 subclass of B (這裡用 A < B 表示), 則 List[A] < List[B]. 從 OO 的觀點, 這表示 List[A] 可以被當成 List[B] 用在所有 List[B] 出現的地方. 但實際上卻不然, List[B].add(B) 就不該能用 List[A].add(B) 才對. Java 的 array 就是 covariant, 變得會允許下面這種不正當的操作: String[] s = new String[5]; Object[] o = s; // array is covariant so this is allowed o[3] = new Object(); String name = s[3]; // throws ArrayStoreException ! 反過來, Contravariant 就更令我納悶了, 如果定義 List[-T], 表示當 B < A, 則 List[A] < List[B]... that makes my head spin... 所以如果用 Java 的 pseudo code 來表示, 變成: Object[] o = new Object[5]; String[] s = o; // this is allowed if contravariant 真的會有好的理由在實務上需要這樣的 variant 嗎? 在我自己的感覺, 這種功能造成的問題可能比解決的問題還多... 最後 Invariant, 這就很直接了, 如果定義 List[T], 則不論 A < B 或 B < A, List[A] 跟 List[B] 互相完全沒關係, 這最保守, 最不會干擾 OO 的語意, 但是也最不靈活. Java 的 type parameter 就選擇了這種, 只是加上了一些 bounded type 定義 讓它稍微靈活一點, 但基本上還是 Invariant. 或許 template based polymorphism 本質上就跟 class based polymorphism 不一樣, 所以湊在一起就是會有衝突的地方吧? 感覺上 Java 比較保守, 盡量維持 class based typing 的一致性, 而 Scala 就蠻大膽的, 全部放進去看看大家怎麼用 (functional programming? anyone? ...) 哈, 突然想到一句話: "High explosives, handle with care." --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 118.165.166.80
1F:推 godfat:久違的心得好感動啊... 晚了明日再回 @@ 03/15 01:48
2F:推 jaiyalas:簡直感動到痛哭流涕呀 ~ 03/17 09:44







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燈, 水草

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

TOP