摘要:在拋出異常的情況下,原理也是和上面的一樣的,你把上面說到的換成去理解就了
原文地址:java 異常捕捉 ( try catch finally ) 你真的掌握了嗎?
前言:
java 中的異常處理機制你真的理解了嗎?掌握了嗎?
catch 體里遇到 return 是怎么處理? finally 體遇到 return 怎么辦?finally 體里有 System.exit() 方法怎么處理?當(dāng) catch 和 finally 體里同時遇上 return 怎么辦?
相信你在處理異常的時候不是每次都把它 throws 掉就完事了,很多時候異常是需要我們自己來 catch 并針對所拋出的 Exception 做一些后續(xù)的處理工作。
直接上代碼,先貼下面測試需要調(diào)用的方法:
1 2 // catch 后續(xù)處理工作 3 public static boolean catchMethod() { 4 System.out.print("call catchMethod and return --->> "); 5 return false; 6 } 7 // finally后續(xù)處理工作 8 public static void finallyMethod() { 9 System.out.println(); 10 System.out.print("call finallyMethod and do something --->> "); 11 } 12
拋出 Exception,沒有 finally,當(dāng) catch 遇上 return
1 2public static boolean catchTest() { 3 try { 4 int i = 10 / 0; // 拋出 Exception,后續(xù)處理被拒絕 5 System.out.println("i vaule is : " + i); 6 return true; // Exception 已經(jīng)拋出,沒有獲得被執(zhí)行的機會 7 } catch (Exception e) { 8 System.out.println(" -- Exception --"); 9 return catchMethod(); // Exception 拋出,獲得了調(diào)用方法并返回方法值的機會 10 } 11 } 12
后臺輸出結(jié)果:
1 2 -- Exception -- 3call catchMethod and return --->> false 4
拋出 Exception,當(dāng) catch 體里有 return,finally 體的代碼塊將在 catch 執(zhí)行 return 之前被執(zhí)行
1 2public static boolean catchFinallyTest1() { 3 try { 4 int i = 10 / 0; // 拋出 Exception,后續(xù)處理被拒絕 5 System.out.println("i vaule is : " + i); 6 return true; // Exception 已經(jīng)拋出,沒有獲得被執(zhí)行的機會 7 } catch (Exception e) { 8 System.out.println(" -- Exception --"); 9 return catchMethod(); // Exception 拋出,獲得了調(diào)用方法的機會,但方法值在 finally 執(zhí)行完后才返回 10 }finally{ 11 finallyMethod(); // Exception 拋出,finally 代碼塊將在 catch 執(zhí)行 return 之前被執(zhí)行 12 } 13 } 14
后臺輸出結(jié)果:
1 2 -- Exception -- 3call catchMethod and return --->> 4call finallyMethod and do something --->> false 5
不拋 Exception,當(dāng) finally 代碼塊里面遇上 return,finally 執(zhí)行完后將結(jié)束整個方法
1 2public static boolean catchFinallyTest2() { 3 try { 4 int i = 10 / 2; // 不拋出 Exception 5 System.out.println("i vaule is : " + i); 6 return true; // 獲得被執(zhí)行的機會,但執(zhí)行需要在 finally 執(zhí)行完成之后才能被執(zhí)行 7 } catch (Exception e) { 8 System.out.println(" -- Exception --"); 9 return catchMethod(); 10 }finally{ 11 finallyMethod(); 12 return false; // finally 中含有 return 語句,這個 return 將結(jié)束這個方法,不會在執(zhí)行完之后再跳回 try 或 catch 繼續(xù)執(zhí)行,方法到此結(jié)束,返回 false 13 } 14 } 15
后臺輸出結(jié)果:
1 2i vaule is : 5 3 4call finallyMethod and do something --->> false 5
不拋 Exception,當(dāng) finally 代碼塊里面遇上 System.exit() 方法 將結(jié)束和終止整個程序,而不只是方法
1 2public static boolean finallyExitTest() { 3 try { 4 int i = 10 / 2; // 不拋出 Exception 5 System.out.println("i vaule is : " + i); 6 return true; // 獲得被執(zhí)行的機會,但由于 finally 已經(jīng)終止程序,返回值沒有機會被返回 7 } catch (Exception e) { 8 System.out.println(" -- Exception --"); 9 return true;
10 }finally {
11 finallyMethod();
12 System.exit(0);// finally 中含有 System.exit() 語句,System.exit() 將退出整個程序,程序?qū)⒈唤K止
13 }
14 }
15
后臺輸出結(jié)果:
1 2i vaule is : 5 3 4call finallyMethod and do something --->> 5
拋出 Exception,當(dāng) catch 和 finally 同時遇上 return,catch 的 return 返回值將不會被返回,finally 的 return 語句將結(jié)束整個方法并返回
1
2public static boolean finallyTest1() {
3 try {
4 int i = 10 / 0; // 拋出 Exception,后續(xù)處理被拒絕
5 System.out.println("i vaule is : " + i);
6 return true; // Exception 已經(jīng)拋出,沒有獲得被執(zhí)行的機會
7 } catch (Exception e) {
8 System.out.println(" -- Exception --");
9 return true; // Exception 已經(jīng)拋出,獲得被執(zhí)行的機會,但返回操作將被 finally 截斷 10 }finally { 11 finallyMethod(); 12 return false; // return 將結(jié)束整個方法,返回 false 13 } 14 } 15
后臺輸出結(jié)果:
1 2 -- Exception -- 3 4call finallyMethod and do something --->> false 5
不拋出 Exception,當(dāng) finally 遇上 return,try 的 return 返回值將不會被返回,finally 的 return 語句將結(jié)束整個方法并返回
1 2public static boolean finallyTest2() { 3 try { 4 int i = 10 / 2; // 不拋出 Exception 5 System.out.println("i vaule is : " + i); 6 return true; // 獲得被執(zhí)行的機會,但返回將被 finally 截斷 7 } catch (Exception e) { 8 System.out.println(" -- Exception --"); 9 return true;
10 }finally {
11 finallyMethod();
12 return false; // return 將結(jié)束這個方法,不會在執(zhí)行完之后再跳回 try 或 catch 繼續(xù)執(zhí)行,返回 false
13 }
14 }
15
后臺輸出結(jié)果:
1 2i vaule is : 5 3 4call finallyMethod and do something --->> false 5
結(jié)語:
(假設(shè)方法需要返回值)
java 的異常處理中,
在不拋出異常的情況下,程序執(zhí)行完 try 里面的代碼塊之后,該方法并不會立即結(jié)束,而是繼續(xù)試圖去尋找該方法有沒有 finally 的代碼塊,
如果沒有 finally 代碼塊,整個方法在執(zhí)行完 try 代碼塊后返回相應(yīng)的值來結(jié)束整個方法;
如果有 finally 代碼塊,此時程序執(zhí)行到 try 代碼塊里的 return 語句之時并不會立即執(zhí)行 return,而是先去執(zhí)行 finally 代碼塊里的代碼,
若 finally 代碼塊里沒有 return 或沒有能夠終止程序的代碼,程序?qū)⒃趫?zhí)行完 finally 代碼塊代碼之后再返回 try 代碼塊執(zhí)行 return 語句來結(jié)束整個方法;
若 finally 代碼塊里有 return 或含有能夠終止程序的代碼,方法將在執(zhí)行完 finally 之后被結(jié)束,不再跳回 try 代碼塊執(zhí)行 return。
在拋出異常的情況下,原理也是和上面的一樣的,你把上面說到的 try 換成 catch 去理解就 OK 了 _
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/65909.html
摘要:不相等的對象要具有不相等的哈希碼為了哈希表的操作效率,這一點很重要,但不是強制要求,最低要求是不相等的對象不能共用一個哈希碼。方法和方法協(xié)同工作,返回對象的哈希碼。這個哈希碼基于對象的身份生成,而不是對象的相等性。 本文面向 剛學(xué)完Java的新手們。這篇文章不講語法,而是一些除了語法必須了解的概念。 將要去面試的初級工程師們。查漏補缺,以免遭遇不測。 目前由于篇幅而被挪出本文的知識...
捕獲和處理異常 本節(jié)描述如何使用三個異常處理程序組件 — try、catch和finally塊 — 來編寫異常處理程序,然后,解釋了Java SE 7中引入的try-with-resources語句,try-with-resources語句特別適用于使用Closeable資源的情況,例如流。 本節(jié)的最后一部分將介紹一個示例,并分析各種場景中發(fā)生的情況。 以下示例定義并實現(xiàn)名為ListOfNumbe...
摘要:程序執(zhí)行時,至少會有一個線程在運行,這個運行的線程被稱為主線程。程序的終止是指除守護線程以外的線程全部終止。多線程程序由多個線程組成的程序稱為多線程程序。線程休眠期間可以被中斷,中斷將會拋出異常。 線程 我們在閱讀程序時,表面看來是在跟蹤程序的處理流程,實際上跟蹤的是線程的執(zhí)行。 單線程程序 在單線程程序中,在某個時間點執(zhí)行的處理只有一個。 Java 程序執(zhí)行時,至少會有一個線程在運行...
摘要:拆箱將包裝類型轉(zhuǎn)換為基本類型的過程。否則會拋出異常。默認采用單鏈表解決沖突,如果鏈表長度超過,將單鏈表轉(zhuǎn)換為紅黑樹。內(nèi)部使用紅黑樹實現(xiàn),存儲映射。紅黑樹減弱了對平衡的要求,降低了保持樹平衡需要的開銷,在實際應(yīng)用中,統(tǒng)計性能超過平衡二叉樹。 引言 showImg(https://segmentfault.com/img/bVbv7Mr?w=242&h=410); 在學(xué)習(xí)《Java編程的邏...
閱讀 550·2021-11-25 09:44
閱讀 2636·2021-11-24 09:39
閱讀 2305·2021-11-22 15:29
閱讀 3520·2021-11-15 11:37
閱讀 3379·2021-09-24 10:36
閱讀 2507·2021-09-04 16:41
閱讀 992·2021-09-03 10:28
閱讀 1833·2019-08-30 15:55