国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

Java 8:lambda表達式中的強制檢查異常處理。為什么是強制性的而不是可選性的?

瀏覽:111日期:2024-04-24 08:55:54
如何解決Java 8:lambda表達式中的強制檢查異常處理。為什么是強制性的而不是可選性的??

不確定我是否真的回答了您的問題,但是您不能簡單地使用類似的內容嗎?@H_301_1@

public final class supplierUtils { private supplierUtils() { } public static <T> supplier<T> wrap(Callable<T> callable) {return () -> { try {return callable.call(); } catch (RuntimeException e) {throw e; } catch (Exception e) {throw new RuntimeException(e); }}; }}public class JdbcConnectionPool extends ObjectPool<Connection> { public JdbcConnectionPool(int maxConnections, String url) {super(supplierUtils.wrap(() -> DriverManager.getConnection(url)), maxConnections); }}解決方法

我正在使用Java 8的新lambda功能,發現Java 8提供的實踐確實很有用。但是,我想知道是否有一種 很好的方法來解決以下情況。假設您有一個對象池包裝器,需要某種工廠來填充對象池,例如(使用java.lang.functions.Factory):

public class JdbcConnectionPool extends ObjectPool<Connection> { public ConnectionPool(int maxConnections,String url) {super(new Factory<Connection>() { @Override public Connection make() {try { return DriverManager.getConnection(url);} catch ( SQLException ex ) { throw new RuntimeException(ex);} }},maxConnections); }}

將功能接口轉換為lambda表達式后,上面的代碼變為:

public class JdbcConnectionPool extends ObjectPool<Connection> { public ConnectionPool(int maxConnections,String url) {super(() -> { try {return DriverManager.getConnection(url); } catch ( SQLException ex ) {throw new RuntimeException(ex); }},maxConnections); }}

確實還算不錯,但是檢查的異常java.sql.SQLException需要在lambda內部加上try/catch塊。在我公司,我們長時間使用兩個接口:

IOut<T>相當于java.lang.functions.Factory;還有一個特殊的接口,用于通常需要檢查異常傳播的情況:interface IUnsafeOut<T,E extends Throwable> { T out() throws E; }。

這兩個IOut<T>和IUnsafeOut<T>應該遷移到Java 8中被刪除,但是不存在用于精確匹配IUnsafeOut<T,E>。如果lambda表達式可以像未檢查的那樣處理已檢查的異常,則可以在上面的構造函數中像下面這樣簡單地使用它:

super(() -> DriverManager.getConnection(url),maxConnections);

看起來更干凈了。我看到可以重寫ObjectPool超類來接受我們的IUnsafeOut<T>,但是據我所知,Java8尚未完成,因此可能會有一些變化,例如:

實現類似于IUnsafeOut<T,E>?(說實話,我認為這很臟-受試者必須選擇接受什么:Factory不能兼容的方法簽名的“不安全工廠”)只是忽略了lambda中的檢查異常,因此不需要IUnsafeOut<T,E>代理嗎?(為什么不這樣做?例如,另一個重要的變化:我使用的OpenJDK javac現在不需要將變量和參數聲明為final在匿名類[功能接口]或lambda表達式中捕獲)

因此,問題通常是:有沒有辦法繞過lambda中的檢查異常,還是在Java 8最終發布之前計劃在將來進行?

更新1

嗯,據我所知,盡管參考文章的日期為2010年,但看來目前尚無辦法:BrianGoetz解釋了Java中的異常透明性。如果Java8中沒有太大變化,則可以認為是答案。Brian也說interface ExceptionalCallable<V,E extendsException>(我在IUnsafeOut<T,E extends Throwable>代碼遺留中提到的內容)幾乎沒有用,我同意他的觀點。

我還想念其他東西嗎?

標簽: java
相關文章:
主站蜘蛛池模板: 男操美女 | 亚洲免费成人 | 国产一区二区三区成人久久片 | 精品91自产拍在线 | 在线欧美成人 | 日韩日b视频 | 亚洲高清自拍 | 日韩a毛片免费全部播放完整 | 欧美成人性动漫在线观看 | 极品国产在线 | 亚洲国产日韩欧美 | 一区二区高清在线 | 国产精品黄网站免费观看 | 自拍偷拍欧美视频 | 午夜影院免费体验 | 九九精品在线观看 | 三级黄色高清视频 | 91精品国产91热久久久久福利 | 91久国产在线观看 | 久久中文字幕久久久久 | 亚洲一级黄色毛片 | 免费成年网 | 国产成人91一区二区三区 | 精品无码久久久久久国产 | 欧美成人毛片在线视频 | 99精品视频99 | 不卡一级aaa全黄毛片 | 亚洲日本中文字幕在线 | 国产精品免费视频一区 | 中国一级毛片录像 | 免费毛片播放 | 巨乳女上司| 高清一级毛片免免费看 | 日本一级视频 | 成年网在线观看免费观看网址 | 96精品视频在线播放免费观看 | 久久久这里只有精品免费 | 国产一区二区三区免费在线视频 | 欧美深夜影院 | 日本国产免费一区不卡在线 | 性做久久久久久免费观看 |