jianchen 写道
当你确信方法的使用者会处理你的方法抛出的异常时,可以使用编译时异常。不处理编译时异常,程序编译不能通过。
而运行时异常给了方法的调用者以选择,他可以选择处理,也可以不处理。处理的话,进行catch即可,不处理的话就什么也不做就是了。不处理运行时异常,程序编译能够通过。
在网上搜到一篇现成的文章,链接如下:
原文:http://blog.csdn.net/xkqtest/archive/2008/04/10/2275676.aspx
Java提供了两类主要的异常:runtime exception和checked exception。checked
异常也就是我们经常遇到的IO异常,以及SQL异常都是这种异常。对于这种异常,JAVA编译器强制要求我们必需对出现的这些异常进行catch。所以,
面对这种异常不管我们是否愿意,只能自己去写一大堆catch块去处理可能的异常。
但是另外一种异常:runtime exception,也称运行时异常,我们可以不处理。当出现这样的异常时,总是由虚拟机接管。比如:我们从来没有人去处理过NullPointerException异常,它就是运行时异常,并且这种异常还是最常见的异常之一。
以
前一直没仔细想过出现运行时异常了系统会怎样工作,最近在一个模块排错时,才无意中发现了系统是如何处理运行时异常。出现运行时异常后,系统会把异常一直
往上层抛,一直遇到处理代码。如果没有处理块,到最上层,如果是多线程就由Thread.run()抛出,如果是单线程就被main()抛出。抛出之后,
如果是线程,这个线程也就退出了。如果是主程序抛出的异常,那么这整个程序也就退出了。运行时异常是Exception的子类,也有一般异常的特点,是可
以被Catch块处理的。只不过往往我们不对他处理罢了。
也就是说,你如果不对运行时异常进行处理,那么出现运行时异常之后,要么是线程中止,要么是主程序终止。如果程序的退出刚好是你期望的结果,那就万事OK了。
但
最近我在项目却遇的问题,恰恰是这因为没有对运行时异常进行处理,而导致程序在运行一小段时间后就当了。事情是这样的,由于写程序时我对多线程的并发处理
不太会,也就把一个模块写成了单线程的,由它来循环处理一个数据队列。但没想到队列里面的数据有一些与预期的格式不一样,处理这样的数据时,程序就抛出了
运行时异常。由于没有对异常进行处理,这个异常也就抛到了Thread.run()。最后这个处理线程肯定是被终止了,队列里面的数据也就不会再有程序去
处理了。这个结果显然不是我想要的,队列里面出现异常数据了,正常的处理应该是把异常数据舍弃,然后记录日志。不应该由于异常数据而,影响下面对正常数据
的处理啊。
所以最后我在程序的循环处理模块,里面加了一个catch处理,来扑捉所有的异常,决不让这个处理线程退出,要知道我的所
有数据还要依靠他来处理呢 (^_^
)。在这个场景这样处理可能是一个比较好的应用,但并不代表在所有的场景你都应该如此。如果在其它场景,遇到了一些错误,如果退出程序比较好,这时你就可
以不太理会运行时异常,或者是通过对异常的处理显式的控制程序退出。
知道了虚拟机怎么处理运行时异常,也更进一步理解了Sping对
Hibernate的封装了。由于Hibernate是和数据库打交道,所以总是要抛出一些乱七八糟的checked异常,平时我们根本不想catch这
些异常。因为这些异常总是把代码弄的乱乱的,搞的到处都是try{}
catch(){}块,并且常常加了catch块,也并不能把程序从异常中恢复过来(异常处理的目标之一就是为了把程序从异常中恢复出来)。为了通过编译
器的检查,程序员被迫加上了catch块,往往这些catch并没有发挥他应有的作用,反而带来了很大的不便。所以Spring对Hibernate封装
时就把Hibernate的异常进行了封装,全部封装成运行时异常了。也就是Spring来扑捉Hibernate抛出的异常,然后Spring把异常转
换成Spring自己定义的运行时异常再抛出。这样我们在编码时使用Spring来调用Hibernate时,可以不用catch块来处理一些不必要的异
常。当然你确实要是想处理,也可以通过添加cathc块去处理异常。不过这个时候,你的Catch就要扑捉运行时异常了,而不是一般的checked异常
了。
分享到:
相关推荐
而Exception则代表可恢复的错误,它可以分为运行时异常和编译时异常。 运行时异常(RuntimeException)指的是那些在程序运行时才可能发生的异常情况,例如空指针异常(NullPointerException)、数组越界异常...
最后,C运行时库还提供了一些内部的全局变量和函数,例如异常终止处理、各种数学函数的辅助函数、链接器支持的函数、运行时库的动态CAS操作等,这些通常不为普通程序开发者所直接使用,但对于库的开发和维护具有重要...
9. **检查异常和运行时异常**:Java区分了检查异常(如`IOException`)和运行时异常(如`NullPointerException`)。检查异常是那些在编译时必须处理的异常,而运行时异常在运行时才抛出,可以选择捕获。 通过这个...
JAVA程序设计中的异常和断言是程序开发过程中的重要概念,它们帮助开发者处理程序运行时可能出现的问题,确保程序的稳定性和可靠性。 异常处理是JAVA语言中的一个关键特性,用于处理程序执行过程中出现的非正常情况...
6. **VC编译环境**:在Windows平台下,Visual C++是常用的C++开发环境,它提供了完整的编译、调试和测试工具,使得开发者能方便地构建和运行libsvm程序。 7. **可运行程序**:这里提到的"可以运行的程序"可能是指...
首先,我们来区分两种基本类型的错误:编译错误和运行错误。编译错误是由于源代码违反了Java语法规则,编译器在编译阶段会检测到并报告这些错误。只有当所有编译错误都被修正后,代码才能被成功编译为字节码或目标码...
7. **实时调试**: 对于开发阶段,异常处理库还可能提供实时调试功能,如热重载,让开发者能够快速发现并修复问题,而无需频繁地重新编译和安装应用。 以`master-atul-react-native-exception-handler-d88d14a`为例...
1. **区分运行时异常和检查性异常**:运行时异常通常是编程错误,应该尽量避免;而检查性异常是应用程序可以预见并应该处理的异常。 2. **不要滥用异常**:异常处理机制应仅用于处理真正意义上的异常情况,而非控制...
7. **运行时支持**:除了编译器本身,编译器还需要提供运行时库支持,如内存管理(动态分配和释放)、异常处理等。TINY+可能包含一个小型的运行时系统来支持其编译出的程序。 学习编译原理TINY+有助于理解编程语言...
### ASP.NET 编译运行速度优化技巧 #### 一、使用高效的数据结构 在ASP.NET应用中,选择合适的数据结构可以显著提升程序的性能。例如,`ArrayList`是一种灵活但性能较低的选择,尤其是在处理大量数据时。为了提高...
- **错误处理**:处理编译和运行过程中的异常,向用户显示友好的错误消息。 在实现以上功能的过程中,会涉及C#的基础语法、Windows Forms控件的使用、文件I/O操作、进程控制、正则表达式以及可能的图形渲染技术。这...
异常处理是现代编程语言中一项非常重要的特性,尤其对于像C++这样的语言来说,它可以帮助开发者更好地管理那些不可预见但可预料的运行时错误。 ### 异常处理的基本思想 异常处理的基本思想是通过一种机制来捕获和...
首先,我们要区分两种类型的异常:checked异常和unchecked异常。Checked异常是那些在编译时就需要被捕获或声明的异常,比如IOException和SQLException。它们通常代表了程序中可以预见的错误,需要调用者处理或传递给...
7. **错误处理(Error Handling)**:在编译过程中,可能会遇到语法错误、类型错误或其他异常,良好的编译器需要能够准确地报告错误位置和性质,帮助用户快速定位问题。 8. **链接(Linking)**:当一个程序由多个...
`Throwable`类是所有异常和错误的基类,它定义了一些基本的方法,如`toString()`、`printStackTrace()`等,用于获取异常的详细信息。`Exception`类进一步分为编译时异常(`RuntimeException`之外的所有`Exception`)...
总的来说,语义分析的编译原理涉及到多个层次的理解和处理,包括但不限于类型系统、上下文规则、代码优化和错误检测,它是确保程序能够在目标环境中正确运行的关键步骤。在实际的编译器设计和实现中,开发者需要深入...
- Java 区分检查异常和运行时异常,这有助于在编译时发现潜在的问题。 2. **异常处理机制**: - C++ 的异常处理更注重性能,异常抛出和捕获的开销相对较小。 - Java 的异常处理机制更为丰富,提供了更多工具和...
因此,在使用反编译代码时,确保你有合法的使用权是非常重要的。 接下来,我们要关注“学习”这个标签。对于初学者而言,反编译的项目代码提供了一个实践的机会,让他们可以看到实际的编程实践,了解代码是如何组织...
对checked异常和unchecked异常进行区分的原因是编译器将检查是否为所有的checked异常提供了异常处理机制。如果程序中没有处理checked异常,编译器将报错。这样可以确保程序的正确性和可靠性。 四、应该对哪些异常...