溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java 8中怎么利用lambda表達(dá)式處理異常

發(fā)布時間:2021-07-02 13:57:57 來源:億速云 閱讀:145 作者:Leah 欄目:大數(shù)據(jù)

本篇文章為大家展示了java 8中怎么利用lambda表達(dá)式處理異常,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

簡介

java 8中引入了lambda表達(dá)式,lambda表達(dá)式可以讓我們的代碼更加簡介,業(yè)務(wù)邏輯更加清晰,但是在lambda表達(dá)式中使用的Functional Interface并沒有很好的處理異常,因為JDK提供的這些Functional Interface通常都是沒有拋出異常的,這意味著需要我們自己手動來處理異常。

因為異常分為Unchecked Exception和checked Exception,我們分別來討論。

處理Unchecked Exception

Unchecked exception也叫做RuntimeException,出現(xiàn)RuntimeException通常是因為我們的代碼有問題。RuntimeException是不需要被捕獲的。也就是說如果有RuntimeException,沒有捕獲也可以通過編譯。

我們看一個例子:

List<Integer> integers = Arrays.asList(1,2,3,4,5);
       integers.forEach(i -> System.out.println(1 / i));

這個例子是可以編譯成功的,但是上面有一個問題,如果list中有一個0的話,就會拋出ArithmeticException。

雖然這個是一個Unchecked Exception,但是我們還是想處理一下:

        integers.forEach(i -> {
           try {
               System.out.println(1 / i);
           } catch (ArithmeticException e) {
               System.err.println(
                       "Arithmetic Exception occured : " + e.getMessage());
           }
       });

上面的例子我們使用了try,catch來處理異常,簡單但是破壞了lambda表達(dá)式的最佳實踐。代碼變得臃腫。

我們將try,catch移到一個wrapper方法中:

    static Consumer<Integer> lambdaWrapper(Consumer<Integer> consumer) {
       return i -> {
           try {
               consumer.accept(i);
           } catch (ArithmeticException e) {
               System.err.println(
                       "Arithmetic Exception occured : " + e.getMessage());
           }
       };
   }

則原來的調(diào)用變成這樣:

integers.forEach(lambdaWrapper(i -> System.out.println(1 / i)));

但是上面的wrapper固定了捕獲ArithmeticException,我們再將其改編成一個更通用的類:

    static <T, E extends Exception> Consumer<T>
   consumerWrapperWithExceptionClass(Consumer<T> consumer, Class<E> clazz) {

       return i -> {
           try {
               consumer.accept(i);
           } catch (Exception ex) {
               try {
                   E exCast = clazz.cast(ex);
                   System.err.println(
                           "Exception occured : " + exCast.getMessage());
               } catch (ClassCastException ccEx) {
                   throw ex;
               }
           }
       };
   }

上面的類傳入一個class,并將其cast到異常,如果能cast,則處理,否則拋出異常。

這樣處理之后,我們這樣調(diào)用:

integers.forEach(
               consumerWrapperWithExceptionClass(
                       i -> System.out.println(1 / i),
                       ArithmeticException.class));

處理checked Exception

checked Exception是必須要處理的異常,我們還是看個例子:

    static void throwIOException(Integer integer) throws IOException {
   }
List<Integer> integers = Arrays.asList(1, 2, 3, 4, 5);
       integers.forEach(i -> throwIOException(i));

上面我們定義了一個方法拋出IOException,這是一個checked Exception,需要被處理,所以在下面的forEach中,程序會編譯失敗,因為沒有處理相應(yīng)的異常。

最簡單的辦法就是try,catch住,如下所示:

        integers.forEach(i -> {
           try {
               throwIOException(i);
           } catch (IOException e) {
               throw new RuntimeException(e);
           }
       });

當(dāng)然,這樣的做法的壞處我們在上面已經(jīng)講過了,同樣的,我們可以定義一個新的wrapper方法:

    static <T> Consumer<T> consumerWrapper(
           ThrowingConsumer<T, Exception> throwingConsumer) {

       return i -> {
           try {
               throwingConsumer.accept(i);
           } catch (Exception ex) {
               throw new RuntimeException(ex);
           }
       };
   }

我們這樣調(diào)用:

integers.forEach(consumerWrapper(i -> throwIOException(i)));

我們也可以封裝一下異常:

static <T, E extends Exception> Consumer<T> consumerWrapperWithExceptionClass(
           ThrowingConsumer<T, E> throwingConsumer, Class<E> exceptionClass) {

       return i -> {
           try {
               throwingConsumer.accept(i);
           } catch (Exception ex) {
               try {
                   E exCast = exceptionClass.cast(ex);
                   System.err.println(
                           "Exception occured : " + exCast.getMessage());
               } catch (ClassCastException ccEx) {
                   throw new RuntimeException(ex);
               }
           }
       };
   }

然后這樣調(diào)用:

integers.forEach(consumerWrapperWithExceptionClass(
               i -> throwIOException(i), IOException.class));

上述內(nèi)容就是java 8中怎么利用lambda表達(dá)式處理異常,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI