您好,登錄后才能下訂單哦!
在Java8中使用Stream時需要注意哪些事項?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
Stream簡介
Stream是元素的集合,這點讓Stream看起來用些類似Iterator;
可以支持順序和并行的對原Stream進行匯聚的操作;
//Lists是Guava中的一個工具類 List<Integer> nums = Lists.newArrayList(1,null,3,4,null,6); nums.stream().filter(num -> num != null).count();
引子
今天下午遇到一個NPE,如下圖所示
跟了下源碼,最后跟到ReferencePipeline#193行,應該是調用apply的時候,入參u為null,從而觸發了空指針異常。
@Override @SuppressWarnings("unchecked") public final <R> Stream<R> map(Function<? super P_OUT, ? extends R> mapper) { Objects.requireNonNull(mapper); return new StatelessOp<P_OUT, R>(this, StreamShape.REFERENCE, StreamOpFlag.NOT_SORTED | StreamOpFlag.NOT_DISTINCT) { @Override Sink<P_OUT> opWrapSink(int flags, Sink<R> sink) { return new Sink.ChainedReference<P_OUT, R>(sink) { @Override public void accept(P_OUT u) { downstream.accept(mapper.apply(u)); } }; } }; }
為了驗證我的想法,我寫了如下的測試例子:
public static void main(String[] args) { List<Long> res = Arrays.asList(1L, 2L, null); res.stream().map(UserReadServiceImpl::get).collect(Collectors.toList()); } public static Long get(long userId) { return userId; }
最佳實踐
在Streams開始和結束之前,都需要避免處理null值,使用filter可以過濾掉;
不要濫用Streams,因為我發現Stream有時候會讓代碼變得更難以閱讀;
針對Collections的迭代處理,可以多用Stream處理;
要謹慎使用Parallel Streams,性能不一定比普通的loop要好;
最后,對外暴露API的入參檢查需要更全面;
關于在Java8中使用Stream時需要注意哪些事項問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。