java常见异常
- 格式:doc
- 大小:30.00 KB
- 文档页数:7
bigdecimal 空指针-回复标题:解析Bigdecimal 空指针异常及解决方法引言:在Java 编程中,空指针异常(NullPointerException)是一种常见的错误。
本文将详细讨论Bigdecimal 类中的空指针异常及其相关原因,并提供一步一步的解决方法。
第一步:了解BigDecimal 类BigDecimal 类位于java.math 包中,用于处理任意精度的十进制数。
它提供了高精度的运算和舍入方式,通常用于金融和财务计算。
然而,在使用BigDecimal 时,我们常常会遇到空指针异常。
第二步:发生空指针异常的原因在使用BigDecimal 进行计算时,若其实例为null,就有可能触发空指针异常。
例如,当我们调用方法或访问实例变量时,如果实例对象为空,就会导致空指针异常的发生。
第三步:如何避免空指针异常避免空指针异常的最佳方法是对可能为空的对象进行空指针检查。
以下是几种常见的方法:1. 使用条件语句:在访问BigDecimal 实例前使用条件判断,确保其非空。
javaif (bigDecimalObj != null) {执行对BigDecimal 实例的操作}2. 使用Optional 类:Optional 类是Java 8 中引入的新特性,旨在处理可能为空的对象。
通过使用Optional 类,我们可以使用链式调用来避免空指针异常。
javaOptional<BigDecimal> optionalBigDecimalObj =Optional.ofNullable(bigDecimalObj); optionalBigDecimalObj.ifPresent(obj -> {执行对BigDecimal 实例的操作});3. 使用Objects 类的requireNonNull 方法:Objects 类是Java 7 中引入的工具类,其中的requireNonNull 方法可用于检查方法参数是否为空。
Java的异常处理标准主要遵循Java语言的异常处理机制。
异常处理是Java语言的重要特性之一,它用于处理运行时出现的错误和异常情况。
Java的异常处理机制基于以下几个标准:
1.捕获异常:Java使用try-catch语句块来捕获和处理异常。
在try块中,程
序编写人员定义可能会抛出异常的代码,而在catch块中,则定义处理这些异常的代码。
2.声明异常:Java要求程序员在方法签名中声明可能会抛出的异常。
这称为
异常声明。
通过异常声明,Java编译器可以强制程序员处理可能出现的异常。
3.抛出异常:当程序运行时遇到错误或异常情况时,Java允许程序员使用
throw语句抛出异常。
4.自定义异常:Java允许程序员创建自己的异常类,以便更好地描述和处理
特定情况下的错误。
5.finally块:Java还提供了finally块,用于定义无论是否发生异常都需要执
行的代码。
无论try块中的代码是否抛出异常,finally块中的代码都会执行。
这些标准共同构成了Java的异常处理机制,帮助程序员更好地管理和处理程序中的错误和异常情况。
浅析Java异常处理机制及应用摘要:Java异常处理机制是Java编程语言中最为重要的机制之一,它可以在代码中处理各种类型的异常。
本文将对Java异常处理机制进行浅析,并从应用层面探讨一些常见的Java异常处理方法。
关键词:Java,异常处理,应用正文:一、Java异常处理机制Java异常处理机制是Java编程语言中最为重要的机制之一。
在Java语言中,异常是指一个程序运行时产生的意外情况,可以是代码中的错误,也可以是由于外部环境因素导致的错误。
Java提供了一整套异常处理机制,可以帮助开发者处理各种类型的异常。
在Java中,异常通常被定义为继承自Throwable类的任意一个子类。
常见的异常类型包括RuntimeException、IOException、ClassNotFoundException、ArithmeticException等等。
Java中异常的处理主要分为两种方式:try-catch块和throws语句。
try-catch块是一种捕捉异常的方法,其基本语法结构如下:```try {// 可能会抛出异常的代码块} catch (type1 e1) {// 处理type1类型异常的代码块} catch (type2 e2) {// 处理type2类型异常的代码块} finally {// 不管是否发生异常,都会执行的代码块}```throws语句是一种抛出异常的方法,其基本语法结构如下:```public void methodName() throws ExceptionType {// 可能会抛出异常的代码块}```二、Java异常处理的应用Java异常处理机制应用广泛,以下是应用层面探讨一些常见的Java异常处理方法。
1、基于try-catch块的异常处理try-catch块是Java中最基本的异常处理方法。
它可以在程序运行时捕捉异常,并且根据不同的异常类型采取不同的处理方法。
异常1,Java中的异常处理机制的简单原理和应用当java程序违反了java的语义规则时,java虚拟机(JVM)就会将发生的错误表示为一个异常。
违反语义规则包括2种情况。
一种是Jjava类库内置的语义检查。
例如数组下标越界,会引发IndexOutOfBoundsException;访问null的对象时会引发NullPointerException。
另一种情况就是允许程序员扩展这种语义检查,程序员可以创建自己的异常,并自由选择在何时用throw关键字引发异常。
所有的异常都是ng.Thowable的子类。
2,Error与Exception有什么区别?error 表示恢复不是不可能但很困难的情况下的一种严重问题。
比如说内存溢出。
不可能指望程序能处理这样的情况exception 表示一种设计或实现问题。
也就是说,它表示如果程序运行正常,从不会发生的情况3,运行时异常与一般异常有何异同?异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机通常操作中可能遇到的异常,是一种常见运行错误。
java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。
4,JAVA语言如何进行异常处理,关键字:throws,throw,try,catch,finally分别代表什么意义?Java通过面向对象的方法进行异常处理,把各种不同的异常进行分类,并提供了良好的接口。
在Java中,每个异常都是一个对象,它是Throwable类或其它子类的实例。
当一个方法出现异常后便抛出一个异常对象,该对象中包含有异常信息,调用这个对象的方法可以捕获到这个异常并进行处理。
Java的异常处理是通过5个关键词来实现的:try、catch、throw、throws和finally。
一般情况下是用try来执行一段程序,如果出现异常,系统会抛出(throws)一个异常,这时候你可以通过它的类型来捕捉(catch)它,或最后(finally)由缺省处理器来处理。
浅谈java中异常抛出后代码是否会继续执⾏问题今天遇到⼀个问题,在下⾯的代码中,当抛出运⾏时异常后,后⾯的代码还会执⾏吗,是否需要在异常后⾯加上return语句呢?public void add(int index, E element){if(size >= elements.length) {throw new RuntimeException("顺序表已满,⽆法添加");//return; //需要吗?}....}为了回答这个问题,我编写了⼏段代码测试了⼀下,结果如下://代码1public static void test() throws Exception {throw new Exception("参数越界");System.out.println("异常后"); //编译错误,「⽆法访问的语句」}//代码2try{throw new Exception("参数越界");}catch(Exception e) {e.printStackTrace();}System.out.println("异常后");//可以执⾏//代码3if(true) {throw new Exception("参数越界");}System.out.println("异常后"); //抛出异常,不会执⾏总结:若⼀段代码前有异常抛出,并且这个异常没有被捕获,这段代码将产⽣编译时错误「⽆法访问的语句」。
如代码1若⼀段代码前有异常抛出,并且这个异常被try...catch所捕获,若此时catch语句中没有抛出新的异常,则这段代码能够被执⾏,否则,同第1条。
如代码2若在⼀个条件语句中抛出异常,则程序能被编译,但后⾯的语句不会被执⾏。
如代码3另外总结⼀下运⾏时异常与⾮运⾏时异常的区别:运⾏时异常是RuntimeException类及其⼦类的异常,是⾮受检异常,如NullPointerException、IndexOutOfBoundsException等。
在Java编程中,空指针异常是一种常见的bug,可能会导致程序的崩溃和不可预测的后果。
为了避免这种情况,我们可以采用一些技巧和方法来规避空指针异常的发生。
在本文中,我将共享5个避免空指针异常的案例,帮助大家更好地理解和避免这一常见问题。
1. 使用Optional类在Java 8及以后的版本中,引入了Optional类,它可以帮助我们明确地表示一个值可能是缺失的情况。
通过使用Optional类,我们可以避免直接使用可能为空的引用,从而避免空指针异常的发生。
我们可以使用Optional.ofNullable方法来创建一个可能为空的对象,然后通过isPresent方法来判断是否存在数值,以及通过orElse方法来提供一个默认值。
2. 使用断言在编程的过程中,我们经常会有一些假设,例如某个对象不会为空。
通过使用断言来验证这些假设,可以帮助我们及早地发现潜在的空指针异常。
在Java程序中,我们可以使用断言关键字assert来检查一个条件是否为真,如果条件为假,程序将抛出AssertionError异常。
通过在程序中添加适当的断言,我们可以有效地避免空指针异常的发生。
3. 避免链式调用在Java编程中,我们经常会使用链式调用来操作对象,例如a.getB().getC().doSomething()。
然而,如果a、b或c中的任何一个为null,就会导致空指针异常。
为了避免这种情况,我们可以将链式调用拆分成多个步骤,逐步进行空指针检查,确保每一步操作的对象都不为null,从而避免空指针异常的出现。
4. 使用Objects.requireNonNull在编写Java代码时,可以使用Objects.requireNonNull方法来检查方法的参数是否为null。
如果参数为null,将抛出NullPointerException异常,从而避免在后续的代码中出现空指针异常。
通过在方法的开头添加适当的参数检查,可以有效地规避空指针异常的发生。
"Test1.java": class Test2 is public; should be declared in a file named Test2.java at line 3, column 1错误解释:"Test1.java": 类Test2是公共类,应该在名为Test2.java的文件中被宣告3行1列处解决方案:1、修改类名或文件名,保证两者一致//////////////////////////////////////////错误提示:"Test1.java": cannot resolve symbol: class Connection in class com.he.Test1 at line 5, column 5错误解释:"Test1.java": 不能识别的标志(类):在类com.he.Test1中的类Connection 5行5列处可能原因:1、没有引包,如java.sql.*2、Connection类名拼写错误//////////////////////////////////////////错误提示:"Test1.java": incompatible types;found : int,required: ng.String at line 6, column 16错误解释:"Test1.java": 数据类型矛盾;发现:int,要求:String 6行16列处可能原因:1、声明类型与赋值类型不一致2、方法声明的返回类型与实际的返回类型不一致3、所调用方法的返回类型与方法调用处的接受变量类型不一致//////////////////////////////////////////错误提示:"Test1.java": cannot resolve symbol: variable a1 in class com.he.Test1 at line 7, column 24错误解释:"Test1.java": 不能识别的标志(变量):在类com.he.Test1中的变量a1 7行24列处可能原因:1、变量未声明2、变量名拼写错误3、在声明的范围之外使用变量,如{}之外//////////////////////////////////////////错误提示:"Test1.java": cannot resolve symbol: method parserInt (ng.String)in class ng.Integer at line 9, column 21错误解释:"Test1.java": 不能识别的标志(方法):在类ng.Integer中的方法parserInt(ng.String) 9行21列处可能原因:1、方法名拼写错误2、方法参数类型不匹配//////////////////////////////////////////错误提示:"Test1.java": '}' expected at line 13, column 2错误解释:"Test1.java": 期望'}' 13行2列处可能原因:1、大括号不匹配//////////////////////////////////////////错误提示:"Test1.java": unreported exception ng.ClassNotFoundException; must be caught or declared to be thrown at line 11, column 11错误解释:"Test1.java": 未报告的异常ng.ClassNotFoundException;必须被捕获或是被声明抛出11行11列处解决方案:1、用try{}catch(){}捕获异常2、在方法声明时用throws ...,... 声明该方法抛出异常特别提示:为便于程序调试时异常定位,强烈建议在进行异常捕获时打印堆栈信息( ex.printStactTrace() )//////////////////////////////////////////错误提示:"Test1.java": non-static variable info cannot be referenced from a static context at line 17, column 24错误解释:"Test1.java": 非静态的变量info不能在静态上下文(环境)中引用17行24列处解决方案:1、声明对象调用其静态变量2、修改方法为非静态方法//////////////////////////////////////////错误提示:"Test1.java": b is already defined in main(ng.String[]) at line 19, column 5错误解释:"Test1.java": (变量)b在(方法)main(ng.String[])中已经被定义*行*列处解决方案:1、修改(变量)名称//////////////////////////////////////////错误提示:"Test1.java": test() is already defined in com.he.Test1 at line 25, column 3错误解释:"Test1.java": (方法)test()在(类)com.he.Test1中已经被定义*行*列处解决方案:1、修改(方法)名称2、修改(方法)参数,即方法重载//////////////////////////////////////////错误提示:"Test.java": Duplicate definition of class com.he.Test1, defined in D:\JavaStudy\TempPro\src\com\he\Test.java and also defined in D:\JavaStudy\TempPro\src\com\he\Test1.java.错误解释:"Test.java":重复定义了类com.he.Test1,在D:\JavaStudy\TempPro\src\com\he\Test.java与D:\JavaStudy\TempPro\src\com\he\Test1.java中都定义了解决方案:1、修改类名特别提示:如果修改后仍然提示该错,可以通过删除对应class文件来解决//////////////////////////////////////////错误提示:"Test1.java": variable d might not have been initialized at line 22, column 22错误解释:"Test1.java":变量d可能还没有被初始化*行*列处可能原因:1、在某种情况下,有可能使用没有被初始化的变量特别提示:[代码]String a;int x=1;if(x>0) a="正数";System.out.println(a);[修改]String a=null;...//////////////////////////////////////////错误提示:"Test1.java": unreachable statement at line 25, column 5错误解释:"Test1.java": 无法到达的语句*行*列处可能原因:1、死循环导致其后的语句没有可能到达2、return 语句导致其后的语句没有可能到达特别提示:[代码]int a=1;if(a>0) {return "正数";}else {return "非正数";}//没有可能到达a=0;//////////////////////////////////////////错误提示:"Test1.java": missing return statement at line 29, column 23错误解释:"Test1.java": (方法)缺失return语句*行*列处解决方案:1、1、确保(方法)在所有可能下都有return语句,如果声明时不是void //////////////////////////////////////////错误提示:"Test1.java": Package D:\JavaStudy\TempPro\src\com\he\Test1.java stated in source com.he1 does not match directoryD:\JavaStudy\TempPro\src\com\he\Test1.java. at line 1, column 13错误解释:"Test1.java": 类的包声明(package ...)与类实际所处包路径不匹配*行*列处解决方案:1、修改包声明,确保与类实际所处包路径一致//////////////////////////////////////////错误提示:"Test1.java": <identifier> expected at line 3, column 14错误解释:"Test1.java": 期望标志符*行*列处可能原因:1、标志符不可法,如类名用数字开头//////////////////////////////////////////错误提示:"Test1.java": call to super must be first statement in constructor at line 6, column 10错误解释:"Test1.java": 在构造函数中调用父类构造函数super(...)必须位于第一句*行*列处解决方案:1、将语句super(...)位于第一句//////////////////////////////////////////错误提示:"Test1.java": 'try' without 'catch' or 'finally' at line 20, column 5错误解释:"Test1.java": 'try'缺失'catch' 或'finally' *行*列处解决方案:1、'try'必须与'catch'和'finally'两者中至少其一进行搭配使用//////////////////////////////////////////错误提示:"Test1.java": illegal character: \65307 at line 4, column 12错误解释:"Test1.java": 非法字符*行*列处可能原因:1、使用了中文的符号,如括号,逗号,分号,冒号等//////////////////////////////////////////错误提示:"Test1.java": reference to Date is ambiguous; both class java.sql.Date in java.sql and class java.util.Date in java.util match at line 6, column 9错误解释:"Test1.java": 对(类)Date的引用不明确;包java.sql中的类java.sql.Date与包java.util中的类java.util.Date都与之相配(即两个包中都有该类) *行*列处解决方案:1、声明或实例化时使用类全名(即包名+类名),如java.util.Date d = new java.util.Date();//////////////////////////////////////////错误提示:"Test1.java": cannot resolve symbol: constructor Integer ()in class ng.Integer at line 6, column 17错误解释:"Test1.java": 不能识别的标志(构造函数):类ng.Integer中的构造函数Integer() *行*列处可能原因:1、调用构造函数时的参数与其原始定义不一致//////////////////////////////////////////.apache.jasper.JasperException: Unable to compile class forJSPAn error occurred at line: -1 in the jsp file: null告诉你的已经很明显了,你不懂英语吗?都是你的jsp文件不存在了,看是不是路径错了Q: 运行javac HelloWorld.java 为何error:cannot read:HelloWorld.java 1 errorA: 首先检查文件名的的拼写,大小写是否正确,再看目录是否正确。
提示ng.UnsupportedClassVersionError: Bad version numberin .class fileMyeclipse 使用的JDK和Tomcat使用的JDK版本不一致解决方法:把它们的JDK版本改成一致步骤如下:1.Window --> Preferences -->Java --> compiler中的compiler compliance level对应的下拉菜单中选择JDK版本.2.Window --> Preferences -->MyEclipse --> Servers -->Tomcat --> Tomcat n.x -->JDK中的Tomcat JDK name下的下拉菜单中选择自身电脑上安装的JDK 版本1 、缺少文件上传JAR包commons-io-1.3.1.jar commons-fileupload-1.2.jarUnable to load beanorg.apache.struts2.dispatcher.multipart.MultiPartRequest (jakarta) - [unknown location]这个问题是在使用Struts2想做一个上传文件的页面时候Tomcat报出来的错误,详细信息如下:2007-7-19 21:34:09 org.apache.catalina.core.StandardWrapperValve invoke严重: Servlet.service() for servlet jsp threw exceptionng.RuntimeException: Unable to load beanorg.apache.struts2.dispatcher.multipart.MultiPartRequest (jakarta) - [unknown location]问题描述:使用Struts2.0.6+Sitemesh2.2.1+Freemark2.3.8的过程中,装饰Action请求的结果页面不会有问题,但是如果装饰直接访问的JSP页面会出现如下错误:java 代码1. javax.servlet.ServletException: Error applying decorator: null解决方案:经过调试发现是FreeMarkerPageFilter的getLocale方法没有对invocation添加非空判断造成的,错误代码如下:java 代码1. protected Locale getLocale(ActionInvocation invocation, Configurationconfiguration) {2. if (invocation.getAction() instanceof LocaleProvider) {3. return ((LocaleProvider) invocation.getAction()).getLocale();4. } else {5. return configuration.getLocale();6. }7. }改正后的代码如下:java 代码1. protected Locale getLocale(ActionInvocation invocation, Configurationconfiguration) {2. if (invocation != null && invocation.getAction() instanceof LocaleProvider) {3. return ((LocaleProvider) invocation.getAction()).getLocale();4. } else {5. return configuration.getLocale();6. }7. }问题描述:使用Struts2.0.6+Sitemesh2.2.3,我有一个请求/customer/page.action,其结果页面为WEB-INF/jsp/customer/list.jsp,我希望使用main装饰器对返回结果进行装饰,如果配置如下:xml 代码1. <decorator name="main" page="main.ftl">2. <pattern>/WEB-INF/jsp/customer/list.jsppattern>3. decorator>则无法成功进行装饰,如果配置如下:xml 代码1. <decorator name="main" page="main.ftl">2. <pattern>/*pattern>3. decorator>则可以成功进行装饰。
《Java开发常见问题解答》Java是一种高级编程语言,被广泛应用于当今世界各个领域,包括企业应用开发、Android应用开发、Web应用开发等。
其广泛使用也引发了一系列问题。
本篇文章将针对Java开发中的一些常见问题进行解答,帮助开发者更好地应对和解决这些问题。
一、内存泄漏问题Java虚拟机(JVM)在为Java程序提供内存资源的同时,也为程序提供内存管理服务。
但是,由于Java语言的垃圾回收机制不像C语言一样由程序员自行管理,因此可能导致内存泄漏问题。
内存泄漏指的是程序在执行过程中无法释放已经分配的内存,使得程序的内存空间被不必要地占用。
解决方案:1.使用内存分析工具,如Eclipse Memory Analyzer和VisualVM等,搜索并定位内存泄漏代码。
2.规范使用Java API,如Collection类等,在使用完后及时将其释放。
3.避免使用静态集合类,避免Object类中的finalize()方法。
二、多线程同步问题多线程同步问题是Java开发中最常见和棘手的问题之一。
由于多个线程对共享数据进行访问,因此可能导致线程安全问题,如死锁、线程调度等。
解决方案:1.使用线程同步机制,在共享数据的前提下,控制多个线程的访问。
例如,使用synchronized关键字实现同步。
2.使用线程局部变量,该变量仅在线程内部可见,不影响其他线程。
3.使用线程池,减少线程频繁创建和销毁的开销。
三、字符串操作效率问题Java中字符串的操作效率常常受到开发者的重视。
由于字符串操作过程中的对象创建和销毁对程序效率的影响较大,因此需要针对性地解决字符串操作效率问题。
解决方案:1.使用StringBuilder类和StringBuffer类,避免频繁创建新的字符串对象,提高效率。
2.使用String的intern()方法,将字符串存储在常量池中,节省内存,提高效率。
3.避免使用“+”连接符进行字符串拼接,避免不必要的内存开销。
1. java.lang.nullpointerexception 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针", 简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错 误等等。对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,即把数组的初始化和数组元素的初始化混淆起来了。数组的初始化是对数 组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,所以还需要对每个元素都进行初始化(如果要调用的话)
2. 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(int red,int green,int blue)这个方法中的三个值,如果有超过255的也会出现这个异常,因此一旦发现这个异常,我们要做的,就是赶紧去检查一下方法调用中的参数传递是不是出现了错误。
6. java.lang.illegalaccessexception 这个异常的解释是"没有访问权限",当应用程序要调用一个类,但当前的方法即没有对该类的访问权限便会出现这个异常。对程序中用了package的情况下要注意这个异常。
其他还有很多异常,我就不一一列举了,我要说明的是,一个合格的程序员,需要对程序中常见的问题有相当的了解和相应的解决办法,否则仅仅停留在写程序而不会改程序的话,会极大影响到自己的开发的。关于异常的全部说明,在api里都可以查阅。
算术异常类: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或大于等于序列大小时,抛出该异常。