Re: Lambda 和Streams 可以慢5倍

作者: eieio (好多目標)   2015-12-03 03:52:22
※ 引述《Lordaeron (Terry)》之銘言:
: http://tinyurl.com/ndw5g39
: 這個看起來很慘!!
: 但
: http://tinyurl.com/ne83u8f
: 這個看起來, 又很好呢.
標題太誤導人了。我兩邊都仔細看了,stream 或 parallelStream 應該是較
佳的寫法。慢五倍的關鍵並不是 stream,而是 boxing/unboxing
integers.stream().reduce(...)
integers.stream().mapToInt(Integer::intValue).reduce(...)
上面兩個寫法,有先 mapToInt 就可以避免掉過多的 boxing/unboxing,速度
跟 for loop 差不多。
同樣的道理,下面這段 code 很不好:
String r = "";
for (String s : strs) {
r = r + s;
}
上面這段 code,每次 r = r + s 就會產生一個新的 String,效能會很低。
要避免產生無用的 String,要用 StringBuilder。
作者: longlongint (華哥爾)   2015-12-03 06:02:00
不可修改內容的物件都要注意
作者: eieio (好多目標)   2015-12-03 08:52:00
good point
作者: Lordaeron (Terry)   2015-12-03 11:27:00
你要不要回文反駁一下? 做數據出來反駁?
作者: eieio (好多目標)   2015-12-06 09:36:00
原文就有人提了,數據早更新了,你自己標題殺人怪我?

Links booklink

Contact Us: admin [ a t ] ucptt.com