亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Java8Stream異常處理

瀏覽:132日期:2024-02-04 11:01:34

問題描述

我也是剛用上Java8的Stream,所有的一切都還在照貓畫虎的階段。

在異常處理這塊不敢貿然前進,因為我看到某篇文的這樣一段話

在單線程環境中,使用捕獲受檢異常并重新拋出非受檢異常的方法是可行的。但是在多線程環境這樣用,就存在一些風險。

多線程環境中,Lambda表達式中發生的錯誤會被自動傳遞到主線程中。這會帶來兩個問題:

這不會停止其他正在并行執行的Lambda表達式。如果有多個線程拋出了異常,在主線程中卻只能捕獲到一個線程中的異常。如果這些異常信息都很重要的話,那么更好的方法是在Lambda表達式中就進行異常處理并將異常信息作為結果的一部分返回到主線程中。

我現在是用的Stream流的Map方法,當然用的是并發,想在map里的方法里只要有一個出錯就讓他停下來,不運行其他的。。這個需求該怎么搞。。

paths.stream() .map(path -> {try { return new File(path).getCanonicalPath();} catch(IOException ex) { throw new RuntimeException(ex);} }) .forEach(System.out::println);

我用了這種方法確實停下來了,那還有什么好的方法,或者說是否有何問題,這樣的話就拿不到具體哪個線程有問題了吧

問題解答

回答1:

你的思維模式就不對,map filter 這類不是語法糖, java8還是有函數式編程能力的。函數式的核心是不變性,這里不是要求取消變量,而是要建立一種等價思維,以求值 > 過程的方式去思考問題。

你的例子,比如要求在map中停下來這就在設計之外,因為map的語意保證了它一定會遍歷完所有數據,返回的類型一定一致,而且長度相同。同樣貿然拋出rumtime exception也是非常的不優雅。

有幾個方案,使用optional或者either(這個官方不提供,需要自己弄一個)來包裝你的返回類型來保證map語義(把錯誤放到返回值里去,但是類型不變,具體可以百度)

如果你的數據有前后關系,使用fold(reduce)來處理而不是map。

不使用stream而用回for break,編程其實就是編程,關鍵是解決問題,針對問題來選擇最好的方案,有的時候steam方案不如傳統的for,fork/join也不如手工sync notify。

另,stream的并行其實沒有你想的那么好,濫用了copyonwrite,我自己玩過一陣之后幾乎再也不用了。不過 java8有個completableFuture估計能滿足你的要求。

回答2:

CountDownLatch(1)

catch異常時:

CountDownLatch.countDown();

最后:

CountDownLatch.await();xxx.stop();

Java8的Stream沒用過了。。。

標簽: java
相關文章:
主站蜘蛛池模板: 国产午夜免费一区二区三区 | 正在播放的国产a一片 | a一级毛片录像带 录像片 | 国产在线一区二区三区欧美 | 亚洲影视一区二区 | 在线观看亚洲人成网站 | 欧美三级短视频 | 国产精品99在线观看 | 婷婷情| 日韩精品另类天天更新影院 | 中文字幕日韩精品一区口 | 久久国产精品一国产精品金尊 | 日韩女同一区二区三区 | 一级黄色片一级片 | 国产精品 主播精选 网红 | 免费看一毛一级毛片视频 | 欧美俄罗斯一级毛片激情 | 美女扒开胸罩露出奶了无遮挡免费 | 国产美女亚洲精品久久久久久 | 麻豆91av| 日本一级特级毛片视频 | 欧美三级免费看 | 草逼综合 | 最新欧美精品一区二区三区 | 波多野吉衣一区二区三区四区 | 久久伊人精品综合观看99 | 亚洲狠狠97婷婷综合久久久久 | 色综合91久久精品中文字幕 | 国产一级淫片a视频免费观看 | 大人和孩做爰h视频在线观看 | 中国人黑人xxⅹ性猛 | 久久久久久久综合狠狠综合 | 久久草在线视频国产一 | 国产闫盼盼私拍福利精品视频 | 亚洲色图套图 | 激情六月丁香婷婷 | 91精选国产 | 精品一区二区三区在线视频观看 | a一级片 | 久久精品视频6 | 精品国产一区二区三区久久影院 |