0


try catch 嵌套

实践测试

在单元测试中写入以下方法:

  1. testMain()

主方法,

  1. out()

里面嵌套了两层try catch
异常代码写在内层try中

示例一:

  1. @Test
  2. public void testMain(){
  3. out();
  4. log.info("后续处理业务");
  5. }
  6. public void out(){
  7. //外层try
  8. try {
  9. System.out.println("外层输出");
  10. //内层try
  11. try {
  12. int i = 2/0; //异常代码
  13. }catch (Exception e){
  14. log.error("内层异常",e);
  15. }
  16. }catch (Exception e){
  17. log.error("外层异常",e);
  18. }
  19. }

日志信息:
在这里插入图片描述

  1. 外层输出
  2. 20:38:27.172 [main] ERROR com.eshore.paas.ops.serv.secondalert.secondAlertTest - 内层异常
  3. java.lang.ArithmeticException: / by zero
  4. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.out(secondAlertTest.java:52)
  5. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.testMain(secondAlertTest.java:42)
  6. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  7. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  8. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  9. at java.lang.reflect.Method.invoke(Method.java:498)
  10. at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
  11. at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  12. at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
  13. at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  14. at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
  15. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
  16. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
  17. at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
  18. at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
  19. at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
  20. at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
  21. at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
  22. at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
  23. at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
  24. at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
  25. at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
  26. at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:221)
  27. at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:54)
  28. 20:38:27.179 [main] INFO com.eshore.paas.ops.serv.secondalert.secondAlertTest - 后续处理业务

可以看到,内层try中的异常由

  1. 内层catch处理

了,外层catch并未处理,主方法后续业务逻辑并未受到影响,可正常执行.

示例二:

内层try catch中添加

  1. throw new RuntimeException("内层抛出异常",e)

将异常抛出

  1. @Test
  2. public void testMain(){
  3. out();
  4. log.info("后续处理业务");
  5. }
  6. public void out(){
  7. //外层try
  8. try {
  9. System.out.println("外层输出");
  10. //内层try
  11. try {
  12. int i = 2/0;
  13. }catch (Exception e){
  14. log.error("内层异常",e);
  15. //向外抛出异常
  16. throw new RuntimeException("抛出异常",e);
  17. }
  18. }catch (Exception e){
  19. log.error("外层异常",e);
  20. }
  21. }

日志信息:
在这里插入图片描述

  1. 外层输出
  2. 20:47:15.890 [main] ERROR com.eshore.paas.ops.serv.secondalert.secondAlertTest - 内层异常
  3. java.lang.ArithmeticException: / by zero
  4. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.out(secondAlertTest.java:52)
  5. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.testMain(secondAlertTest.java:42)
  6. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  7. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  8. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  9. at java.lang.reflect.Method.invoke(Method.java:498)
  10. at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
  11. at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  12. at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
  13. at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  14. at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
  15. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
  16. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
  17. at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
  18. at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
  19. at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
  20. at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
  21. at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
  22. at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
  23. at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
  24. at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
  25. at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
  26. at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:221)
  27. at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:54)
  28. 20:47:15.894 [main] ERROR com.eshore.paas.ops.serv.secondalert.secondAlertTest - 外层异常
  29. java.lang.RuntimeException: 内层抛出异常
  30. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.out(secondAlertTest.java:55)
  31. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.testMain(secondAlertTest.java:42)
  32. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  33. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  34. at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  35. at java.lang.reflect.Method.invoke(Method.java:498)
  36. at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
  37. at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
  38. at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
  39. at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  40. at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
  41. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
  42. at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
  43. at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
  44. at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
  45. at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
  46. at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
  47. at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
  48. at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
  49. at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
  50. at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
  51. at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
  52. at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:221)
  53. at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:54)
  54. Caused by: java.lang.ArithmeticException: / by zero
  55. at com.eshore.paas.ops.serv.secondalert.secondAlertTest.out(secondAlertTest.java:52)
  56. ... 23 common frames omitted
  57. 20:47:15.894 [main] INFO com.eshore.paas.ops.serv.secondalert.secondAlertTest - 后续处理业务

内层try catch

  1. 向外抛出异常

以后,外层try catch

  1. 捕获了异常

,并打印日志。主方法中后续处理业务逻辑正常执行。

示例三:

在外层try catch中再次将异常抛出

  1. throw new RuntimeException("外层抛出异常",e);
  1. @Test
  2. public void testMain(){
  3. out();
  4. log.info("后续处理业务");
  5. }
  6. public void out(){
  7. //外层try
  8. try {
  9. System.out.println("外层输出");
  10. //内层try
  11. try {
  12. int i = 2/0;
  13. }catch (Exception e){
  14. log.error("内层异常",e);
  15. throw new RuntimeException("内层抛出异常",e);
  16. }
  17. }catch (Exception e){
  18. log.error("外层异常",e);
  19. //向外抛出异常
  20. throw new RuntimeException("外层抛出异常",e);
  21. }
  22. }

日志信息:
在这里插入图片描述

可以看到,程序运行错误。
因为out()方法外层try catch

  1. 抛出异常

以后,主方法并

  1. 未进行处理

导致的

改进:
在主方法中,对out()

  1. 添加一层try catch

进行异常处理:

  1. @Test
  2. public void testMain(){
  3. //添加异常处理
  4. try {
  5. out();
  6. }catch (Exception e){
  7. log.info("处理out()方法异常",e);
  8. }
  9. log.info("后续处理业务");
  10. }
  11. public void out(){
  12. //外层try
  13. try {
  14. System.out.println("外层输出");
  15. //内层try
  16. try {
  17. int i = 2/0;
  18. }catch (Exception e){
  19. log.error("内层异常",e);
  20. throw new RuntimeException("内层抛出异常",e);
  21. }
  22. }catch (Exception e){
  23. log.error("外层异常",e);
  24. throw new RuntimeException("外层抛出异常",e);
  25. }
  26. }

此时可以看到主方法处理异常以后,可以正常向下执行.
在这里插入图片描述

示例四

如果out()方法中的

  1. 异常代码不在try 代码块

中,且主方法也

  1. 没有

对out()方法进行

  1. 异常捕获处理

会怎样?
代码:

  1. @Test
  2. public void testMain(){
  3. out();
  4. log.info("后续处理业务");
  5. }
  6. public void out(){
  7. //添加异常代码,不在try 代码块中
  8. int j = 3/0;
  9. //外层try
  10. try {
  11. System.out.println("外层输出");
  12. //内层try
  13. try {
  14. int i = 2/0;
  15. }catch (Exception e){
  16. log.error("内层异常",e);
  17. throw new RuntimeException("内层抛出异常",e);
  18. }
  19. }catch (Exception e){
  20. log.error("外层异常",e);
  21. throw new RuntimeException("外层抛出异常",e);
  22. }
  23. }

日志:
在这里插入图片描述
程序直接报错

那么该如何处理?
在out()的

  1. 上层方法

即主方法中,

  1. out()进行异常处理
  1. @Test
  2. public void testMain(){
  3. //对out()进行异常处理
  4. try {
  5. out();
  6. }catch (Exception e){
  7. log.info("处理out()方法异常",e);
  8. }
  9. log.info("后续处理业务");
  10. }
  11. public void out(){
  12. int j = 3/0;
  13. //外层try
  14. try {
  15. System.out.println("外层输出");
  16. //内层try
  17. try {
  18. int i = 2/0;
  19. }catch (Exception e){
  20. log.error("内层异常",e);
  21. throw new RuntimeException("内层抛出异常",e);
  22. }
  23. }catch (Exception e){
  24. log.error("外层异常",e);
  25. throw new RuntimeException("外层抛出异常",e);
  26. }
  27. }

日志信息:
在这里插入图片描述
可以看出程序正常执行.

结论:

  1. 下层方法

中的异常代码

  1. 没有在try 代码块

中,只需在

  1. 上层方法

中进行

  1. 异常处理

即可

标签: java spring

本文转载自: https://blog.csdn.net/qq_44209563/article/details/123695520
版权归原作者 qq_44209563 所有, 如有侵权,请联系我们删除。

“try catch 嵌套”的评论:

还没有评论