Re: [新聞] Twitter 改用 Java/Scala 之後...
※ 引述《LaPass (LaPass)》之銘言:
: 看到有人也在找類似的功能,只不過他是在找類似function pointer的東西
: 那,看到他的解法是這樣
: interface IAcetion{
: void invoke();
: }
: 有什麼想執行的方法,包進去,當成變數傳出去就可以了
: 如果是有參數的,就用
: interface IAcetionT1<Tin1>{
: void invoke(Tin1 arg1);
: }
: interface IAcetionT1<Tin1,Tin2>{
: void invoke(Tin1 arg1,Tin2 arg2);
: }
: ......
: 如果需要傳回值的話
: interface IFunc<Tout>{
: Tout call();
: }
: ......
: 想要用閉包的話
: 直接寫個匿名物件繼承IFunc傳回去就可以了
因為
(arg1: Type1, arg2: Type2) => { exprs }
遠比
new IFunc2<T1, T2, T3>{
T3 apply(T1 arg1, T2 arg2){
statement;
}
}
乾淨易懂
: 然後,我實在搞不懂
: Java跟C#已經夠高階了
: 為什麼還要生個新語言去產生Java、C#? orz....
因為語言有(你不見得認同的)缺陷。
你的夠高階不代表其他人覺得夠高階,於是這些覺得不夠高階的人就去弄了新的語言。
以collection來舉例,最早是
int size = col_size;
for(int idx = 0; idx < size; idx++){
statement;
}
後來Java加了
for(ColType var: collection){
statement;
}
Scala變成
collection.map/foreach( mapping function )
你覺得Java很高階嘛?
functional lang.告訴你對collection處理根本不用管
索引值、新collection的暫存等零碎的事情,專心想要怎麼轉換/過濾裡面的元素就好
: 不知道我的理解有沒有錯誤
: Scala是一個新的語言,他最後的結果是生成Java Code
: 也就是說..... 得重新學一遍
對也不對,Scala會被很多學Java的人推薦一部分原因是
因為它跟Java的語法有足夠的相似度,所以上手快。
另外那叫JVM bytecode,並不是輸出成Java,
你這樣講會有很多弄JVM language的人很有意見的:p
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 211.72.92.133
推
11/26 16:27, , 1F
11/26 16:27, 1F
推
11/26 16:42, , 2F
11/26 16:42, 2F
推
11/27 00:38, , 3F
11/27 00:38, 3F
推
11/27 00:43, , 4F
11/27 00:43, 4F
推
11/27 09:22, , 5F
11/27 09:22, 5F
→
11/27 09:25, , 6F
11/27 09:25, 6F
→
11/27 09:26, , 7F
11/27 09:26, 7F
→
11/27 09:32, , 8F
11/27 09:32, 8F
→
11/27 09:35, , 9F
11/27 09:35, 9F
推
11/27 09:39, , 10F
11/27 09:39, 10F
推
11/27 10:02, , 11F
11/27 10:02, 11F
推
11/27 10:03, , 12F
11/27 10:03, 12F
→
11/27 10:04, , 13F
11/27 10:04, 13F
→
11/27 10:06, , 14F
11/27 10:06, 14F
推
11/27 10:10, , 15F
11/27 10:10, 15F
→
11/27 10:13, , 16F
11/27 10:13, 16F
→
11/27 10:15, , 17F
11/27 10:15, 17F
推
11/27 11:04, , 18F
11/27 11:04, 18F
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 4 之 4 篇):