Java异常处理
异常处理
● 概念
● 异常处理
● 激发异常
● 创建自己的异常
● 示例
Java语言的设计从根本上便于我们写出整洁、设计良好的代码;尽管如此,在程序运行中仍可能有各种各样的错误出现。
1、概念
采用新的异常处理机制
在以往的程序开发过程中,常常采用返回值进行处理。例如,在编写一个方法,可以返回一个状态代码,调用者根据状态代码判断出错与否。若状态代码表示一个错误,则调用这进行相应的处理,或显示一个错误页面或错误信息。通过返回值进行处理的方法是有效的,但是有它的许多不足之处。
1、 程序复杂
2、 可靠性差
3、 返回信息有限
4、 返回代码标准化困难
采用错误代码和异常处理相结合的方式的优越性:
1、 把错误代码与常规代码分开
2、 可以在catch中传播错误信息
3、 可以对错误类型分组
4、 方便定位错误,维护
异常
异常就是异常事件,它是程序遇到异常情况所激发的事件。许多异常,如程序错误,空指针,数组溢出等。下面是一个出错流程
上图中:
第一步:插入用户的Keynet,登录系统
第二步:服务器验证用户的身份,判断用户的权限
第三步:返回错误的信息。
这是一个简单的异常处理示例,怎样简单、方便、快捷的得到错误信息。可以采用错误代码和异常两种方式相结合的方式处理。
2、异常处理
Java的异常是面向对象的。一个Java的Exception是一个描述异常情况的对象.当出现异常情况时,一个Exception对象就产生了,并放到异常的成员函数里。
Java的异常处理是通过5个关键词来实现的:try,catch,throw,throws和finally。在Java语言的错误处理结构由try,catch,finally三个块组成。其中try块存放将可能发生异常的Java语言,并管理相关的异常指针;catch块紧跟在try块后面,用来激发被捕获的异常;finally块包含清除程序没有释放的资源,句柄等。不管try块中的代码如何退出,都将执行finally块。
try… catch… 块
可以采用try来指定一块预防所有异常的程序。紧跟在try程序块后面,应包含一个
或多个catch子句来指定你想要捕获的异常类型:try catch的格式一般为:
try{
}catch(…){
…
}catch(…){
…
}
例如:
try{
int a= 100/0
}catch(Exception e){
System.out.println(e.getMessage());
}
每当Java程序激发一个异常时,它实际上是激发了一个对象,而只有其超类为Throwable类的对象才能被激发。Throwable类中的提供了一些方法。如:其中的getMessage()方法打印出异常对应信息。
Catch子句的目标是解决异常情况,把变量设到合理的状态,并象没有出错一样继续运行。如果一个子程序不处理没个异常,则返回到上一级处理,如此可以不断的递归向上直到最外一级。
finally 块
finally 关键字是对 Java 异常处理模型的最佳补充。 finally 结构使代码总会执行,而不管有无异常发生。使用 finally 可以维护对象的内部状态,并可以清理非内存资源。如果没有 finally,您的代码就会很费解。例如,下面的代码说明,在不使用 finally 的情况下您必须如何编写代码来释放非内存资源:
import java.net.*;
import java.io.*;
class WithoutFinally
{
public void foo() throws IOException
{
//在任一个空闲的端口上创建一个套接字
ServerSocket ss = new ServerSocket(0);
try {
Socket socket = ss.accept();
//此处的其他代码...
}
catch (IOException e) {
ss.close(); //1
throw e;
}
//...
ss.close(); //2
}
}
这段代码创建了一个套接字,并调用 accept 方法。在退出该方法之前,您必须关闭此套接字,以避免资源漏洞。为了完成这一任务,我们在 //2 处调用 close,它是该方法的最后一条语句。但是,如果 try 块中发生一个异常会怎么样呢?在这种情况下,//2 处的 close 调用永远不会发生。因此,您必须捕获这个异常,并在重新发出这个异常之前在 //1 处插入对 close 的另一个调用。这样就可以确保在退出该方法之前关闭套接字。
这样编写代码既麻烦又易于出错,但在没有 finally 的情况下这是必不可少的。不幸的是,在没有 finally 机制的语言中,程序员就可能忘记以这种方式组织他们的代码,从而导致资源漏洞。Java 中的 finally 子句解决了这个问题。有了 finally,前面的代码就可以重写为以下的形式:
import java.net.*;
import java.io.*;
class WithFinally
{
public void foo2() throws IOException
{
//在任一个空闲的端口上创建一个套接字
ServerSocket ss = new ServerSocket(0);
try {
Socket socket = ss.accept();
//此处的其他代码...
}
finally {
ss.close();
}
}
}
finally 块确保 close 方法总被执行,而不管 try 块内是否发出异常。因此,可以确保在退出该方法之前总会调用 close 方法。这样您就可以确信套接字被关闭并且您没有泄漏资源。在此方法中不需要再有一个 catch 块。在第一个示例中提供 catch 块只是为了关闭套接字,现在这是通过 finally 关闭的。如果您确实提供了一个 catch 块,则 finally 块中的代码在 catch 块完成以后执行。
finally 块必须与 try 或 try/catch 块配合使用。此外,不可能退出 try 块而不执行其 finally 块。如果 finally 块存在,则它总会执行。(无论从那点看,这个陈述都是正确的。有一种方法可以退出 try 块而不执行 finally 块。如果代码在 try 内部执行一条 System.exit(0); 语句,则应用程序终止而不会执行 finally 执行。另一方面,如果您在 try 块执行期间拨掉电源,finally 也不会执行。)
try…catch…finally 块
最好采用此结构处理异常.在catch中捕获异常,在finally块中清除不需要的资源,这样程序结构将会更完善,健壮.例如:
try{
}
catch(Exception ex){
System.out.println(ex.getMessage());
}
finally{
clearUpAll()
}
3、激发异常
Java语言可以不在方法中直接捕获,而用throw语句将异常抛给上层的调用者。Throw语句就是来明确地抛出一个异常;首先你必需得到一个Throwable的实例句柄,通过参数传到catch中,或者采用new操作符来创建一个。
格式:throw new WhcaException(e.getMessage);
程序会在throw语句后立即终止,它后面的语句都不执行,然后在包含它的所有try块中从里到外寻找含有与其匹配的catch.
声明异常类
当throw语句被用在方法说明中时,throw有用throws代替。关键字throws用来标明一个方法可能抛出的各种异常。对大多数Exception子类来说,Java编译器会强迫你声明在一个方法中抛出的异常的类型。如下:
格式:type method_name(arg_list) throws WhcaException{
……
}
例如:public void execute(String str,int index) throws WhcaException{
try{
}
catch(Exception e){
throw new WhcaException(“JB: M:”+e.getMessage);
}
}
4、创建自己的异常类
当程序员为提供一些特定的功能用Java类时,往往需要保证类之间有良好的关系,而且类之间的接口易于理解和实现,这是定义一个新的异常类。建议创建自己的异常类,便于维护,管理。
定义一个新的异常类
通常采用Exception作为异常类的超类,如:
package whca.common;
public class WhcaException extends Exception{
public WhcaException(){
}
public WhcaException(String s){
super(s);
}
}
5、示例
下面是示例:TestServlet 调用TestDB和TestPsi,(附代码)如果发生异常怎样最快解决程序发生的异常错误。
在整个项目的开发过程中,指定错误代码表,并分类。如PSI类,数据库异常类代码,应用异常类代码,XML异常,网络通讯异常等等;
采用自己的异常类,当遇到异常是,激发的异常携带错误类或异常方法的路径:
如:setFlag(“PSI001”);
throw new WhcaException(“JB:TestA M:exe1 ”+e.getMessage);
这里:PSI001为错误代码,“JB:TestA M:exe1”为异常链,e.getMessage为异常信息。
例如:遇到错误信息列表为:JB:TestB M:exe2 JB:TestA M:exe1 java.sql.SQLException,说明TestB 的方法exe2调用TestA的方法exe1发生了操作数据库异常。则可以迅速,准确的定位到那个类那个方法发生了异常。
注:(简写)JB:JavaBean M:Method
访问数据库类
//Class: TestDB
package corbaidl;
/**
* Title:
* Description:
* Copyright: Copyright (c) 2000
* Company:
* @author
* @version 1.0
*/
import java.io.*;
import java.sql.*;
import whca.common.WhcaException;
public class TestDB {
private PreparedStatement pstmt =null;
private Connection conn = null;
private String flag;
public TestDB() {
}
public void CreateSysMan() throws WhcaException{
try {
/**@todo: CreateSysMan method*/
}
catch (Exception ex) {
setFlag("ORA004");
throw new WhcaException("JB:TestDB M:CreateSysMan ERR="+ex.getMessage());
}
finally {
cleanUpAll();
}
}
public void PublishCert() throws WhcaException{
try {
/**@todo: PublishCert method*/
}
catch (Exception ex) {
setFlag("ORA005");
throw new WhcaException("JB:TestDB M:PublishCert ERR="+ex.getMessage());
}
finally {
cleanUpAll();
}
}
public void cleanUpAll() throws WhcaException {
try {
if (pstmt != null)
pstmt.close();
if (conn != null)
conn.close();
} catch (Exception e) {
throw new WhcaException("JB:RootCaDB M:cleanUpAll Exception" + e.getMessage());
}
}
public void setFlag(String flag) {
this.flag = flag;
}
public String getFlag() {
return flag;
}
}
Psi调用公共类
//Class: TestPsi
package corbaidl;
/**
* Title:
* Description:
* Copyright: Copyright (c) 2000
* Company:
* @author
* @version 1.0
*/
import psi.*;
import whca.common.WhcaException;
public class TestPsi {
private PSIJni psijni;
private String flag;
private int exeHandle=0;
public TestPsi() {
}
public int exePsiInit() throws WhcaException {
try {
//Step 1:psijni init
int ret;
int handle;
psijni = new PSIJni();
ret = psijni.pkiInit();
if (ret != 0) {
setFlag("PSI001");
throw new WhcaException("Initialize library environment failed!");
}
//Step 2:psijni getHandle
handle = psijni.getHandle();
if (handle < 0) {
setFlag("PSI002");
throw new WhcaException("Get handle error");
}
return handle;
} catch (Exception ex) {
throw new WhcaException(ex.getMessage());
}
}
public void exePsiEnd(int handle) throws WhcaException {
try {
psijni.destroyHandle(handle);
psijni.pkiEnd();
} catch (Exception ex) {
throw new WhcaException(ex.getMessage());
}
}
分享到:
相关推荐
- `String`到`Date`:使用`SimpleDateFormat`的`parse`方法,但需要注意异常处理。 - `Date`到`LocalDateTime`:通过`Instant`和`ZoneId`转换,`date.toInstant().atZone(ZoneId.systemDefault()).toLocalDateTime...
综上所述,文档详细介绍了如何使用Java通过JDBC API连接到HighGo数据库的基本步骤,包括了驱动加载、数据库连接建立、异常处理以及代码的版权说明。这些知识点都是Java开发者在进行数据库操作时必须要掌握的基础内容...
此外,理解异常处理机制也是面试中不可或缺的部分。Java使用try-catch-finally语句块来捕获和处理异常,同时提倡使用finally块确保资源的正确释放。理解Checked异常和Unchecked异常的区别,以及如何有效地使用throws...
这篇博客"JAVA数据库连接大全-转载"可能详细介绍了在Java中如何管理和使用数据库连接,包括使用JDBC API,数据库连接池以及相关的工具。这里我们将深入探讨JDBC、数据库连接池的重要性和配置方法。 1. **JDBC基础**...
在安卓应用开发中,异常处理是一项至关重要的任务,因为它能够确保程序在遇到错误时不会突然崩溃,从而提高用户体验。全局异常捕获就是一种机制,它允许开发者统一处理应用程序中的所有未被捕获异常,无论是主线程...
3. **异常处理**:Java的异常处理机制是通过try-catch-finally语句块来实现的。理解如何正确抛出和捕获异常,以及何时使用特定类型的异常,对于编写健壮的代码至关重要。 4. **集合框架**:Java集合框架包括List...
6. 属性表集合:这部分包含非结构化的信息,如类的注解、方法的异常处理、源文件名等。每个属性都有一个预定义的名字和固定格式,或者自定义的属性。 二、字节码指令 字节码指令是Java字节码的核心,它们以单字节的...
Java文件路径操作是Java开发中常见且重要的任务,无论是在读写文件、处理资源还是进行系统交互时,都需要对文件路径进行操作。本篇将详细探讨Java中的文件路径处理技术,主要涵盖以下知识点: 1. **File类**: ...
1. **异常处理**:增强异常处理机制,例如捕获并处理按钮点击过程中的异常。 2. **性能优化**:对于大量计算的任务(如`move`方法中未使用的循环),应考虑将其放在独立的线程中执行,以免影响主程序的流畅度。 3. *...
#### 三、资源管理与异常处理 **3.1 资源管理** - 应当谨慎地管理所有外部资源,如文件句柄或数据库连接。 - 当不再需要这些资源时,应及时释放,避免内存泄漏。 - 使用诸如`try-with-resources`语句来自动关闭资源...
7. 异常:覆盖了Java中的异常处理机制,包括异常类型、抛出异常、捕获异常、自定义异常等。 8. 网络:涉及基于Java的Socket编程,以及HTTP协议和相关的API使用。 9. 设计模式:总结Java中常用的23种设计模式的定义...
7. **异常处理**:为了保证程序的健壮性,开发者会使用try-catch语句来捕获和处理可能出现的异常,例如读取文件时的IOException。 8. **设计模式**:良好的软件设计通常会运用设计模式,比如单例模式用于控制抽奖...
### Java程序员面试知识点详解 ...综上所述,理解Java的基本概念、面向对象的特征、异常处理机制、集合框架以及企业级开发技术,对于Java程序员而言至关重要,特别是在准备面试或深入学习Java开发的过程中。
4. **异常处理**:学习Java中的异常处理机制,包括try-catch-finally语句块,以及自定义异常。通过习题,可以锻炼处理运行时错误的能力。 5. **IO流与NIO**:掌握输入/输出流的基本用法,包括文件操作、网络通信等...
Java作为一门广泛使用的编程语言,其面试题涵盖了众多的知识领域,包括基础语法、面向对象、集合框架、多线程、异常处理、IO流、网络编程、设计模式、JVM优化、数据库操作等。以下是一些Java面试中常被问到的知识点...
- 添加错误处理机制,如文件不存在、读取异常等情况。 以上是Java实现文件下载的基本步骤和注意事项。在提供的"Java实现HTTP文件下载_(转载).txt"文件中,可能包含了具体的示例代码或进一步的解释。通过阅读和理解...
10.1.2 java异常的处理 341 10.2 程序式异常处理 343 10.2.1 在try-catch语句中处理异常 343 10.2.2 使用requestdispatcher来处理异常 346 10.3 小结 349 第11章 开发线程安全的servlet 350 11.1 多线程的...