浅谈Java异常.docx
- 文档编号:5847205
- 上传时间:2023-01-01
- 格式:DOCX
- 页数:14
- 大小:26.41KB
浅谈Java异常.docx
《浅谈Java异常.docx》由会员分享,可在线阅读,更多相关《浅谈Java异常.docx(14页珍藏版)》请在冰豆网上搜索。
浅谈Java异常
异常的好处
异常带来诸多好处。
首先,它将错误处理代码从正常代码(normalcode)中分离出来。
你可以将那些执行概率为99.9%的代码封装在一个try块内,然后将异常处理代码(这些代码是不经常执行的)置于catch子句中。
这种方式的好处是,正常代码因此而更简洁。
如果你不知道如何处理某个方法中的一个特定错误,那么你可以在方法中抛出异常,将处理权交给其他人。
如果你抛出一个检查异常(checkedexception),那么Java编译器将强制客户程序员(cilentprogrammer)处理这个潜在异常,或者捕捉之,或者在方法的throws子句中声明之。
Java编译器确保检查异常被处理,这使得Java程序更为健壮。
Throwable类
Throwable类是Java语言中所有错误或异常的超类(这就是一切皆可抛的东西)。
它有两个子类:
Error和Exception。
Error:
用于指示合理的应用程序不应该试图捕获的严重问题。
这种情况是很大的问题,大到你不能处理了,所以听之任之就行了,你不用管它。
比如说VirtualMachineError:
当Java虚拟机崩溃或用尽了它继续操作所需的资源时,抛出该错误。
好吧,就算这个异常的存在了,那么应该何时,如何处理它呢?
?
交给JVM吧,没有比它更专业的了。
Exception:
它指出了合理的应用程序想要捕获的条件。
Exception又分为两类:
一种是CheckedException,一种是UncheckedException。
这两种Exception的区别主要是CheckedException需要用try...catch...显示的捕获,而UncheckedException不需要捕获。
通常UncheckedException又叫做RuntimeException。
《effectivejava》指出:
对于可恢复的条件使用被检查的异常(CheckedException),对于程序错误(言外之意不可恢复,大错已经酿成)使用运行时异常(RuntimeException)。
我们常见的RuntimeExcepiton有IllegalArgumentException、IllegalStateException、NullPointerException、IndexOutOfBoundsException等等。
对于那些CheckedException就不胜枚举了,我们在编写程序过程中try...catch...捕捉的异常都是CheckedException。
io包中的IOException及其子类,这些都是CheckedException。
检查型异常和非检查型异常
检查型异常是Exception的子类(或者Exception类本身),但不包括RuntimeException和它的子类。
非检查型异常是RuntimeException和它的任何子类。
Error类及其子类也是检查型的(错误),但是你应该仅着眼于异常,你所做的应该是决定抛出RuntimeException的子类(非检查异常)还是Exception的子类(检查异常)
如果抛出了检查型异常(而没有捕获它),那么你需要在方法的throws子句中声明该异常。
客户程序员使用这个方法,他要么在其方法内捕获并处理这个异常,要么还在throws子句中抛出。
检查型异常强制客户程序员对可能抛出的异常采取措施。
如果你抛出的是非检查型异常,那么客户程序员可以决定捕获与否。
然而,编译器并不强制客户程序员对非检查型异常采取措施。
事实上,他们甚至不知道可能这些异常。
显然,在非检查型异常上客户程序员会少费些脑筋。
简单的原则
如果希望客户程序员有意识地采取措施,那么抛出检查型异常。
一般而言,表示类的误用的异常应该是非检查型异常。
String类的chartAt()方法抛出的StringIndexOutOfBoundsException就是一个非检查型异常。
String类的设计者并不打算强制客户程序员每次调用charAt(intindex)时都检查index参数的合法性。
另一方面,java.io.FileInputStream类的read()方法抛出的是IOException,这是一个检查异常。
这个异常表明尝试读取文件时出错了。
这并不意味着客户程序员错误地使用了FileInputStream类,而是说这个方法无法履行它地职责,即从文件中读出下一个字节。
FileInputStream类地设计者认为这个意外情况很普遍,也很重要,因而强制客户程序员处理之。
这就是窍门所在。
如果意外情况是方法无法履行职责,而你又认为它很普遍或很重要,客户程序员必须采取措施,那么抛出检查型异常。
否则,抛出非检查型异常。
结论
异常设计原则:
如果方法遭遇了一个无法处理的意外情况,那么抛出一个异常。
避免使用异常来指出可以视为方法的常用功能的情况。
如果发现客户违反了契约(例如,传入非法输入参数),那么抛出非检查型异常。
如果方法无法履型契约,那么抛出检查型异常,也可以抛出非检查型异常。
如果你认为客户程序员需要有意识地采取措施,那么抛出检查型异常。
Java常见异常表:
Java.lang.nullpointerexception
这个异常大家肯定都经常遇到,异常的解释是:
(程序遇上了空指针),简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等。
对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,即把数组的初始化和数组元素的初始化混淆起来了。
数组的初始化是对数组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,所以还需要对每个元素都进行初始化(如果要调用的话)
Java.lang.classnotfoundexception
这个异常是很多原本在jb等开发环境中开发的程序员,把jb下的程序包放在wtk下编译经常出现的问题,异常的解释是"指定的类不存在",这里主要考虑一下类的名称和路径是否正确即可,如果是在jb下做的程序包,一般都是默认加上package的,所以转到wtk下后要注意把package的路径加上。
3.java.lang.arithmeticexception
这个异常的解释是"数学运算异常",比如程序中出现了除以零这样的运算就会出这样的异常,对这种异常,大家就要好好检查一下自己程序中涉及到数学运算的地方,公式是不是有不妥了。
4.java.lang.arrayindexoutofboundsexception
这个异常相信很多朋友也经常遇到过,异常的解释是"数组下标越界",现在程序中大多都有对数组的操作,因此在调用数组的时候一定要认真检查,看自己调用的下标是不是超出了数组的范围,一般来说,显示(即直接用常数当下标)调用不太容易出这样的错,但隐式(即用变量表示下标)调用就经常出错了,还有一种情况,是程序中定义的数组的长度是通过某些特定方法决定的,不是事先声明的,这个时候,最好先查看一下数组的length,以免出现这个异常。
5.java.lang.illegalargumentexception
这个异常的解释是"方法的参数错误",很多j2me的类库中的方法在一些情况下都会引发这样的错误,比如音量调节方法中的音量参数如果写成负数就会出现这个异常,再比如g.setcolor(intred,intgreen,intblue)这个方法中的三个值,如果有超过255的也会出现这个异常,因此一旦发现这个异常,我们要做的,就是赶紧去检查一下方法调用中的参数传递是不是出现了错误。
6.java.lang.illegalaccessexception
这个异常的解释是"没有访问权限",当应用程序要调用一个类,但当前的方法即没有对该类的访问权限便会出现这个异常。
对程序中用了package的情况下要注意这个异常。
算术异常类:
ArithmeticExecption
空指针异常类:
NullPointerException
类型强制转换异常:
ClassCastException
数组负下标异常:
NegativeArrayException
数组下标越界异常:
ArrayIndexOutOfBoundsException
违背安全原则异常:
SecturityException
文件已结束异常:
EOFException
文件未找到异常:
FileNotFoundException
字符串转换为数字异常:
NumberFormatException
操作数据库异常:
SQLException
输入输出异常:
IOException
方法未找到异常:
NoSuchMethodException
java.lang.AbstractMethodError
抽象方法错误。
当应用试图调用抽象方法时抛出。
java.lang.AssertionError
断言错。
用来指示一个断言失败的情况。
java.lang.ClassCircularityError
类循环依赖错误。
在初始化一个类时,若检测到类之间循环依赖则抛出该异常。
java.lang.ClassFormatError
类格式错误。
当Java虚拟机试图从一个文件中读取Java类,而检测到该文件的内容不符合类的有效格式时抛出。
java.lang.Error
错误。
是所有错误的基类,用于标识严重的程序运行问题。
这些问题通常描述一些不应被应用程序捕获的反常情况。
java.lang.ExceptionInInitializerError
初始化程序错误。
当执行一个类的静态初始化程序的过程中,发生了异常时抛出。
静态初始化程序是指直接包含于类中的static语句段。
java.lang.IllegalAccessError
违法访问错误。
当一个应用试图访问、修改某个类的域(Field)或者调用其方法,但是又违反域或方法的可见性声明,则抛出该异常。
java.lang.IncompatibleClassChangeError
不兼容的类变化错误。
当正在执行的方法所依赖的类定义发生了不兼容的改变时,抛出该异常。
一般在修改了应用中的某些类的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。
java.lang.InstantiationError
实例化错误。
当一个应用试图通过Java的new操作符构造一个抽象类或者接口时抛出该异常.
java.lang.InternalError
内部错误。
用于指示Java虚拟机发生了内部错误。
java.lang.LinkageError
链接错误。
该错误及其所有子类指示某个类依赖于另外一些类,在该类编译之后,被依赖的类改变了其类定义而没有重新编译所有的类,进而引发错误的情况。
java.lang.NoClassDefFoundError
未找到类定义错误。
当Java虚拟机或者类装载器试图实例化某个类,而找不到该类的定义时抛出该错误。
java.lang.NoSuchFieldError
域不存在错误。
当应用试图访问或者修改某类的某个域,而该类的定义中没有该域的定义时抛出该错误。
java.lang.NoSuchMethodError
方法不存在错误。
当应用试图调用某类的某个方法,而该类的定义中没有该方法的定义时抛出该错误。
java.lang.OutOfMemoryError
内存不足错误。
当可用内存不足以让Java虚拟机分配给一个对象时抛出该错误。
java.lang.StackOverflowError
堆栈溢出错误。
当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误。
java.lang.ThreadDeath
线程结束。
当调用Thread类的stop方法时抛出该错误,用于指示线程结束。
java.lang.UnknownError
未知错误。
用于指示Java虚拟机发生了未知严重错误的情况。
java.lang.UnsatisfiedLinkError
未满足的链接错误。
当Java虚拟机未找到某个类的声明为native方法的本机语言定义时抛出。
java.lang.UnsupportedClassVersionError
不支持的类版本错误。
当Java虚拟机试图从读取某个类文件,但是发现该文件的主、次版本号不被当前Java虚拟机支持的时候,抛出该错误。
java.lang.VerifyError
验证错误。
当验证器检测到某个类文件中存在内部不兼容或者安全问题时抛出该错误。
java.lang.VirtualMachineError
虚拟机错误。
用于指示虚拟机被破坏或者继续执行操作所需的资源不足的情况。
java.lang.ArithmeticException
算术条件异常。
譬如:
整数除零等。
java.lang.ArrayIndexOutOfBoundsException
数组索引越界异常。
当对数组的索引值为负数或大于等于数组大小时抛出。
java.lang.ArrayStoreException
数组存储异常。
当向数组中存放非数组声明类型对象时抛出。
java.lang.ClassCastException
类造型异常。
假设有类A和B(A不是B的父类或子类),O是A的实例,那么当强制将O构造为类B的实例时抛出该异常。
该异常经常被称为强制类型转换异常。
java.lang.ClassNotFoundException
找不到类异常。
当应用试图根据字符串形式的类名构造类,而在遍历CLASSPAH之后找不到对应名称的class文件时,抛出该异常。
java.lang.CloneNotSupportedException
不支持克隆异常。
当没有实现Cloneable接口或者不支持克隆方法时,调用其clone()方法则抛出该异常。
java.lang.EnumConstantNotPresentException
枚举常量不存在异常。
当应用试图通过名称和枚举类型访问一个枚举对象,但该枚举对象并不包含常量时,抛出该异常。
java.lang.Exception
根异常。
用以描述应用程序希望捕获的情况。
java.lang.IllegalAccessException
违法的访问异常。
当应用试图通过反射方式创建某个类的实例、访问该类属性、调用该类方法,而当时又无法访问类的、属性的、方法的或构造方法的定义时抛出该异常。
java.lang.IllegalMonitorStateException
违法的监控状态异常。
当某个线程试图等待一个自己并不拥有的对象(O)的监控器或者通知其他线程等待该对象(O)的监控器时,抛出该异常。
java.lang.IllegalStateException
违法的状态异常。
当在Java环境和应用尚未处于某个方法的合法调用状态,而调用了该方法时,抛出该异常。
java.lang.IllegalThreadStateException
违法的线程状态异常。
当县城尚未处于某个方法的合法调用状态,而调用了该方法时,抛出异常。
java.lang.IndexOutOfBoundsException
索引越界异常。
当访问某个序列的索引值小于0或大于等于序列大小时,抛出该异常。
java.lang.InstantiationException
实例化异常。
当试图通过newInstance()方法创建某个类的实例,而该类是一个抽象类或接口时,抛出该异常。
java.lang.InterruptedException
被中止异常。
当某个线程处于长时间的等待、休眠或其他暂停状态,而此时其他的线程通过Thread的interrupt方法终止该线程时抛出该异常。
java.lang.NegativeArraySizeException
数组大小为负值异常。
当使用负数大小值创建数组时抛出该异常。
java.lang.NoSuchFieldException
属性不存在异常。
当访问某个类的不存在的属性时抛出该异常。
java.lang.NoSuchMethodException
方法不存在异常。
当访问某个类的不存在的方法时抛出该异常。
java.lang.NullPointerException
空指针异常。
当应用试图在要求使用对象的地方使用了null时,抛出该异常。
譬如:
调用null对象的实例方法、访问null对象的属性、计算null对象的长度、使用throw语句抛出null等等。
java.lang.NumberFormatException
数字格式异常。
当试图将一个String转换为指定的数字类型,而该字符串确不满足数字类型要求的格式时,抛出该异常。
java.lang.RuntimeException
运行时异常。
是所有Java虚拟机正常操作期间可以被抛出的异常的父类。
java.lang.SecurityException
安全异常。
由安全管理器抛出,用于指示违反安全情况的异常。
java.lang.StringIndexOutOfBoundsException
字符串索引越界异常。
当使用索引值访问某个字符串中的字符,而该索引值小于0或大于等于序列大小时,抛出该异常。
java.lang.TypeNotPresentException
类型不存在异常。
当应用试图以某个类型名称的字符串表达方式访问该类型,但是根据给定的名称又找不到该类型是抛出该异常。
该异常与ClassNotFoundException的区别在于该异常是unchecked(不被检查)异常,而ClassNotFoundException是checked(被检查)异常。
java.lang.UnsupportedOperationException
不支持的方法异常。
指明请求的方法不被支持情况的异常。
异常
javax.servlet.jsp.JspException:
Cannotretrievemappingforaction/Login(/Login是你的action名字)
可能原因
action没有再struts-config.xml中定义,或没有找到匹配的action,例如在JSP文件中使用 formaction="Login.do".将表单提交给Login.do处理,如果出现上述异常,请查看struts-config.xml中的定义部分,有时可能是打错了字符或者是某些不符合规则,可以使用strutsconsole工具来检查。 ---------------------------------------------------------------------------------------------------------------- 异常 org.apache.jasper.JasperException: Cannotretrievedefinitionforformbeannull 可能原因 这个异常是因为Struts根据struts-config.xml中的mapping没有找到action期望的formbean。 大部分的情况可能是因为在form-bean中设置的name属性和action中设置的name属性不匹配所致。 换句话说,action和form都应该各自有一个name属性,并且要精确匹配,包括大小写。 这个错误当没有name属性和action关联时也会发生,如果没有在action中指定name属性,那么就没有name属性和action相关联。 当然当action制作某些控制时,譬如根据参数值跳转到相应的jsp页面,而不是处理表单数据,这是就不用name属性,这也是action的使用方法之一。 ---------------------------------------------------------------------------------------------------------------- 异常 Noactioninstanceforpath/xxxxcouldbecreated 可能原因 特别提示: 因为有很多中情况会导致这个错误的发生,所以推荐大家调高你的web服务器的日志/调试级别,这样可以从更多的信息中看到潜在的、在试图创建action类时发生的错误,这个action类你已经在struts-config.xml中设置了关联(即添加了 在struts-config.xml中通过action标签的class属性指定的action类不能被找到有很多种原因,例如: 定位编译后的.class文件失败。 Failuretoplacecompiled.classfilefortheactionintheclasspath(在web开发中,class的的位置在rWEB-INF/classes,所以你的actionclass必须要在这个目录下。 例如你的action类位于WEB-INF/classes/action/Login.class,那么在struts-config.xml中设置action的属性type时就是action.Login). 拼写错误,这个也时有发生,并且不易找到,特别注意第一个字母的大小写和包的名称 ---------------------------------------------------------------------------------------------------------------- 异常 javax.servlet.jsp.JspException: Nogettermethodforpropertyusernameofbeanorg.apache.struts.taglib.html.BEAN 可能原因 没有位formbean中的某个变量定义getter方法 这个错误主要发生在表单提交的FormBean中,用struts标记 textproperty=”username”>时,在FormBean中必须有一个getUsername()方法。 注意字母“U”。 ---------------------------------------------------------------------------------------------------------------- 异常 java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm 可能原因 这个错误主要发生在在classpath中找不到相应的Java.class文件。 如果这个错误发生在web应用程序的运行时,主要是因为指定的class文件不在webserver的classpath中(/WEB-INF/classes和/WEB-INF/lib)。 在上面的错误中,原因是找不到ActionForm类。 ---------------------------------------------------------------------------------------------------------------- 异常 javax.servlet.jsp.JspException: Excep
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 浅谈 Java 异常