首页 > 其他 > 详细

几种常见的Runtime Exception

时间:2018-03-19 22:01:46      阅读:209      评论:0      收藏:0      [点我收藏+]
    • 摘要:一,error和exception的区别,RuntimeException和非RuntimeException的区别1.异常机制      异常机制是指当程序出现错误后,程序如何处理。具体来说,异常机制提供了程序退出的安全通道。当出现错误后,程序执行的流程发生改变,程序的控制权转移到异常处理器。     传统的处理异常的办法是,函数返回一个特殊的结果来表示出现异常(通
    • 一,error和exception的区别,RuntimeException和非RuntimeException的区别

      1. 异常机制 
            异常机制是指当程序出现错误后,程序如何处理。具体来说,异常机制提供了程序退出的安全通道。当出现错误后,程序执行的流程发生改变,程序的控制权转移到异常处理器。

            传统的处理异常的办法是,函数返回一个特殊的结果来表示出现异常(通常这个特殊结果是大家约定俗称的),调用该函数的程序负责检查并分析函数返回的结果。这样做有如下的弊端:例如函数返回-1代表出现异常,但是如果函数确实要返回-1这个正确的值时就会出现混淆;可读性降低,将程序代码与处理异常的代码混爹在一起;由调用函数的程序来分析错误,这就要求客户程序员对库函数有很深的了解。
      异常处理的流程:
      ① 遇到错误,方法立即结束,并不返回一个值;同时,抛出一个异常对象 。
      ② 调用该方法的程序也不会继续执行下去,而是搜索一个可以处理该异常的异常处理器,并执行其中的代码 。

      2 异常的分类 
      异常的分类:
      ① 异常的继承结构:基类为Throwable,Error和Exception继承Throwable,RuntimeException和IOException等继承Exception,具体的RuntimeException继承RuntimeException。 
      ② Error和RuntimeException及其子类成为未检查异常(unchecked),其它异常成为已检查异常(checked)。

      每个类型的异常的特点 
      Error体系 :
            Error类体系描述了Java运行系统中的内部错误以及资源耗尽的情形。应用程序不应该抛出这种类型的对象(一般是由虚拟机抛出)。如果出现这种错误,除了尽力使程序安全退出外,在其他方面是无能为力的。所以,在进行程序设计时,应该更关注Exception体系。

      Exception体系包括RuntimeException体系和其他非RuntimeException的体系 :
      ① RuntimeException:RuntimeException体系包括错误的类型转换、数组越界访问和试图访问空指针等等。处理RuntimeException的原则是:如果出现RuntimeException,那么一定是程序员的错误。例如,可以通过检查数组下标和数组边界来避免数组越界访问异常。 
      ②其他非RuntimeException(IOException等等):这类异常一般是外部错误,例如试图从文件尾后读取数据等,这并不是程序本身的错误,而是在应用环境中出现的外部错误。

      与C++异常分类的不同 :
      ① Java中RuntimeException这个类名起的并不恰当,因为任何异常都是运行时出现的。(在编译时出现的错误并不是异常,换句话说,异常就是为了解决程序运行时出现的的错误)。 
      ② C++中logic_error与Java中的RuntimeException是等价的,而runtime_error与Java中非RuntimeException类型的异常是等价的。
      3 异常的使用方法 
      声明方法抛出异常 
      ① 语法:throws(略) 
      ② 为什么要声明方法抛出异常? 
            方法是否抛出异常与方法返回值的类型一样重要。假设方法抛出异常却没有声明该方法将抛出异常,那么客户程序员可以调用这个方法而且不用编写处理异常的代码。那么,一旦出现异常,那么这个异常就没有合适的异常控制器来解决。 
      ③ 为什么抛出的异常一定是已检查异常? 
            RuntimeException与Error可以在任何代码中产生,它们不需要由程序员显示的抛出,一旦出现错误,那么相应的异常会被自动抛出。而已检查异常是由程序员抛出的,这分为两种情况:客户程序员调用会抛出异常的库函数(库函数的异常由库程序员抛出);客户程序员自己使用throw语句抛出异常。遇到Error,程序员一般是无能为力的;遇到RuntimeException,那么一定是程序存在逻辑错误,要对程序进行修改(相当于调试的一种方法);只有已检查异常才是程序员所关心的,程序应该且仅应该抛出或处理已检查异常。 
            注意:覆盖父类某方法的子类方法不能抛出比父类方法更多的异常,所以,有时设计父类的方法时会声明抛出异常,但实际的实现方法的代码却并不抛出异常,这样做的目的就是为了方便子类方法覆盖父类方法时可以抛出异常。

      如何抛出异常 
      ① 语法:throw(略) 
      ② 抛出什么异常?对于一个异常对象,真正有用的信息时异常的对象类型,而异常对象本身毫无意义。比如一个异常对象的类型是ClassCastException,那么这个类名就是唯一有用的信息。所以,在选择抛出什么异常时,最关键的就是选择异常的类名能够明确说明异常情况的类。 
      ③ 异常对象通常有两种构造函数:一种是无参数的构造函数;另一种是带一个字符串的构造函数,这个字符串将作为这个异常对象除了类型名以外的额外说明。 
      ④ 创建自己的异常:当Java内置的异常都不能明确的说明异常情况的时候,需要创建自己的异常。需要注意的是,唯一有用的就是类型名这个信息,所以不要在异常类的设计上花费精力。

      捕获异常 
            如果一个异常没有被处理,那么,对于一个非图形界面的程序而言,该程序会被中止并输出异常信息;对于一个图形界面程序,也会输出异常的信息,但是程序并不中止,而是返回用错误页面。
            语法:try、catch和finally(略),控制器模块必须紧接在try块后面。若掷出一个异常,异常控制机制会搜寻参数与异常类型相符的第一个控制器随后它会进入那个catch 从句,并认为异常已得到控制。一旦catch 从句结束对控制器的搜索也会停止。 
            捕获多个异常(注意语法与捕获的顺序)(略) 
            finally的用法与异常处理流程(略) 
            异常处理做什么?对于Java来说,由于有了垃圾收集,所以异常处理并不需要回收内存。但是依然有一些资源需要程序员来收集,比如文件、网络连接和图片等资源。 
            应该声明方法抛出异常还是在方法中捕获异常?原则:捕捉并处理哪些知道如何处理的异常,而传递哪些不知道如何处理的异常。
      再次抛出异常 
      ①为什么要再次抛出异常? 在本级中,只能处理一部分内容,有些处理需要在更高一级的环境中完成,所以应该再次抛出异常。这样可以使每级的异常处理器处理它能够处理的异常。 
      ②异常处理流程 :对应与同一try块的catch块将被忽略,抛出的异常将进入更高的一级。
      4 关于异常的其他问题 
      ① 过度使用异常 :首先,使用异常很方便,所以程序员一般不再愿意编写处理错误的代码,而仅仅是简简单单的抛出一个异常。这样做是不对的,对于完全已知的错误,应该编写处理这种错误的代码,增加程序的鲁棒性。另外,异常机制的效率很差。 
      ② 将异常与普通错误区分开:对于普通的完全一致的错误,应该编写处理这种错误的代码,增加程序的鲁棒性。只有外部的不能确定和预知的运行时错误才需要使用异常。 
      ③ 异常对象中包含的信息 :一般情况下,异常对象唯一有用的信息就是类型信息。但使用异常带字符串的构造函数时,这个字符串还可以作为额外的信息。调用异常对象的getMessage()、toString()或者printStackTrace()方法可以分别得到异常对象的额外信息、类名和调用堆栈的信息。并且后一种包含的信息是前一种的超集。

      总结:Throwable是所有Java程序中错误处理的父类,有两种资类:Error和Exception。
         Error:表示由JVM所侦测到的无法预期的错误,由于这是属于JVM层次的严重错误,导致JVM无法继续执行,因此,这是不可捕捉到的,无法采取任何恢复的操作,顶多只能显示错误信息。
       
        Exception:表示可恢复的例外,这是可捕捉到的。
      Java提供了两类主要的异常:runtime exception和checked exception。checked 异常也就是我们经常遇到的IO异常,以及SQL异常都是这种异常。对于这种异常,JAVA编译器强制要求我们必需对出现的这些异常进行catch。所以,面对这种异常不管我们是否愿意,只能自己去写一大堆catch块去处理可能的异常。

          但是另外一种异常:runtime exception,也称运行时异常,我们可以不处理。当出现这样的异常时,总是由虚拟机接管。比如:我们从来没有人去处理过NullPointerException异常,它就是运行时异常,并且这种异常还是最常见的异常之一。

          出现运行时异常后,系统会把异常一直往上层抛,一直遇到处理代码。如果没有处理块,到最上层,如果是多线程就由Thread.run()抛出,如果是单线程就被main()抛出。抛出之后,如果是线程,这个线程也就退出了。如果是主程序抛出的异常,那么这整个程序也就退出了。运行时异常是Exception的子类,也有一般异常的特点,是可以被Catch块处理的。只不过往往我们不对他处理罢了。也就是说,你如果不对运行时异常进行处理,那么出现运行时异常之后,要么是线程中止,要么是主程序终止。

          如果不想终止,则必须扑捉所有的运行时异常,决不让这个处理线程退出。队列里面出现异常数据了,正常的处理应该是把异常数据舍弃,然后记录日志。不应该由于异常数据而影响下面对正常数据的处理。在这个场景这样处理可能是一个比较好的应用,但并不代表在所有的场景你都应该如此。如果在其它场景,遇到了一些错误,如果退出程序比较好,这时你就可以不太理会运行时异常,或者是通过对异常的处理显式的控制程序退出。

      异常处理的目标之一就是为了把程序从异常中恢复出来。
      二,常见的几种RuntimeException如下: NullPointerException - 空指针引用异常 
      ClassCastException - 类型强制转换异常。 
      IllegalArgumentException - 传递非法参数异常。 
      ArithmeticException - 算术运算异常 
      ArrayStoreException - 向数组中存放与声明类型不兼容对象异常 
      IndexOutOfBoundsException - 下标越界异常 
      NegativeArraySizeException - 创建一个大小为负数的数组错误异常 
      NumberFormatException - 数字格式异常 
      SecurityException - 安全异常 
      UnsupportedOperationException - 不支持的操作异常 

      算术异常类: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
      不支持的方法异常。指明请求的方法不被支持情况的异常。

几种常见的Runtime Exception

原文:https://www.cnblogs.com/cuijiade/p/8605202.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!