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