1、RuntimeException

Exception中有一个特殊的子类异常RuntimeException执行时异常。

假设在函数内容抛出该异常,函数上能够不用声明。编译一样通过。

假设在函数上声明了该异常,调用者能够不用进行处理。编译一样通过。

之所以不用在函数上声明,是由于不须要让调用者处理。

当该异常发生,希望程序停止。

由于在执行时,出现了无法继续运算的情况,

希望停止程序后。对代码进行修正。

例:

class Person
{
public void checkName(String name)
{
//if(name.equals("lisi"))//相当于NullPointerException
if("lisi".equals(name))//相当于if(name!=null && name.equals("lisi"))
System.out.println("YES");
else
System.out.println("No");
}
}
main() //代码简写。。。。要执行自行加上些其它东西
{
Person p=new Person();
p.checkName(null);
}

因此自己定义异常时,假设该异常的发生。无法再继续进行运算,

就让自己定义异常继承RuntimeException。

玩点有趣的。

是不是发现,一有异常程序就停止。

对于异常分两种:

1。编译时被检測的异常。(这时异常是可处理的)

2,编译时不被检測的异常(执行时异常。RuntimeException以及其子类)

异常进入时会进行instanceof推断是否为RuntimeException

2、异常-finally

finally

比如。client与服务端链接。无论是否出现错误都要运行断开操作,

但出现错误client就不需对从服务端读取到的数据进行处理,跳过。

public void method()
{
连接数据库;
数据操作;//throw new SQLException
关闭数据库;//该动作,不管数据操作是否成功。一定要关闭资源 try
{
连接数据库;
数据操作;//throw new SQLException
}
catch(SQLException e)
{
会对数据库进行异常处理;
}
finally
{
关闭数据库;
}
}

3、异常-处理语句其他格式

1,

try{}catch(){}

2,

try{}catch(){}finally{}

3,

try{}finally{//一定要运行的代码}

记住一点:catch是用于处理异常。

假设没有catch就代表异常没有被处理过。假设该异常是检測时异常,那么必须声明。

4、异常-覆盖时的异常特点

1,子类在覆盖父类时,假设父类的方法抛出异常。那么子类的覆盖方法,仅仅能抛出父类的异常或该异常的子类。



假设这样:

class Zi extends Fu
{
void show()throws CException//或者BException。不但是CException
{
}
}

class Test
{
void function(Fu f)
{
f.show();
}
}
class ExceptionDemo7
{
public static void main(String[] args)
{
Test t=new Test();
t.function(new Fu());
}
}





假设Zi真出现C异常。那就在内部处理


2。假设父类的方法抛出多个异常,那么子类在覆盖该方法时,仅仅要父类异常的子集。

3,假设父类或接口的方法中没有异常抛出,那么子类在覆盖方法时,也不可抛出异常。

假设子类发生异常,就必需要进行try处理。绝对不能抛。

5、异常-练习

有一个圆形和长方形,都能够获取面积。

对于面积假设出现非法的数值。视为是获取面积出现故障。

问题通过异常来表示。

6、异常-总结

异常:

是什么?是对问题的描写叙述。将问题进行对象的封装。

异常体系:

Throwable

|--Error

|--Exception

|--RuntimeException

异常体系的特点:异常体系中的全部类以及建立的对象都具备可抛性,

也就是说能够被throw和throwskeyword所操作,

仅仅有异常体系具备这个特点。

------------------------------------------

throw和throws的使用方法:

throw定义在函数内,用于抛出异常对象。

throws定义在函数内,用于抛出异常类,能够抛出多个用逗号隔开。

当函数内容有throw抛出异常对象。并未进行try处理。

必需要在函数上声明。都在编译失败。

注意。RuntimeException除外。

也就是说,函数内假设抛出的RuntimeException异常。函数上能够不用声明。

假设函数声明了异常。调用者须要进行处理,处理方法能够throws能够try。

------------------------------------------

异常有两种:

编译时被检測异常

该异常在编译时,假设没有处理(没有抛也没有try)。编译失败

该异常被标识,代表这能够被处理。

执行时异常(编译时不检測)

在编译时。不须要处理。编译器不检查。

该异常的发生。建议不处理,让程序停止,须要对代码进行修正。

------------------------------------------

异常处理语句:

try{//须要被处理的代码;}catch(){//处理异常的代码;}finally{//一定会运行的代码;}

有三中结合格式:

1、

try{}catch(){}

2、

try{}finally{}

3、

try{}catch(){}finally{}

注意:

1、finally中定义的一般是   关闭资源码。由于资源必须释放。

2、finally仅仅有一种情况不会运行。当运行到System.exit(0);

------------------------------------------

自己定义异常:

定义类继承Exception或者RuntimeException

1,为了让该自己定义类具备可抛性。

2,让该类具备操作异常的共性方法。

当要定义自己定义异常的信息时。能够使用父类已经定义好的功能。

异常信息传递给父类的构造函数。

class MyException extends Exception

{

MyException(String message)

{

super(message);

}

}

------------------------------------------

异常的优点:

1,将问题进行封装

2,将正常流程代码和问题处理代码相分离。方便于阅读。

异常的处理原则:

1,处理方式有两种:try或者throws。

2,调用到抛出异常的功能时,抛出几个。就处理几个。

一个try相应多个catch。

3,多个catch,父类的catch放到最以下。

4,catch内,须要定义针对性的处理方式。不要简单的定义printStackTrace,输出语句。

也不要不写。

当捕获到的异常,本功能处理不了时,能够继续在catch中抛出。

try

{

    throw new AException();

}

catch(AException e)

{

    throw e;

}

假设该异常处理不了,但并不属于该功能出现的异常。

能够将异常转换后。再抛出和该功能相关的异常。



或者异常能够处理,当须要将异常产生的和本功能相关的问题提供出去。

当调用者知道,并处理。

也能够将捕获异常处理后,转换新的异常。

try

{

    throw new AException();

}

catch(AException e)

{

    throw new BException();

}

------------------------------------------

异常的注意事项:

      在子父类覆盖时:

      1。子类抛出的异常必须是父类的异常的子类或者子集。

      2,假设父类或者接口没有异常抛出时,子类覆盖出现异常。仅仅能try不能抛。

      

參阅

ExceptionTest.java  老师用电脑上课

ExceptionTest1.java 图形面积

别样JAVA学习(六)继承下(2.3)异常下的更多相关文章

  1. Java学习笔记---继承和super的用法

    自从换了个视频教学,感觉比原来那个好多了,就是学校网速太渣,好多视频看一会卡半天,只能先看看已经下载的了. 不过也好,虽然不能从开始开始重新开,但是已经看过一次,在看一次也是好的,就当巩固学习了. 继 ...

  2. 别样JAVA学习(五)继承上(1.0)Object类equals()

    上一节继承下(一)我们进行抽象类.接口以及多态的学习. 接下来大家我们讲点特殊的东西就是object类, 我们一直在说继承,子继承了父,父还有没有父类呢, 为什么这么思考,大家想构造函数的第一行是不是 ...

  3. Java学习笔记--继承和多态(下)

    1.通过继承来开发超类(superclass) 2.使用super 关键词唤起超类的构造方法 3.在超类中覆盖方法 4.区分override和overload 5.在Object类中探索toStrin ...

  4. 别样JAVA学习(五)继承上(1.1)Object类toString()

    接下来说完equals以后,我们学习接下来的toString(), Java又觉得全部对象不光具有比較性, 还能使对象变成字符串被打印. 出现 曾经前面显示的是数组.如今显示的是这个对象所属的类. 紧 ...

  5. Java学习笔记--继承和多态(中)

    1.通过继承来开发超类(superclass) 2.使用super 关键词唤起超类的构造方法 3.在超类中覆盖方法 4.区分override和overload 5.在Object类中探索toStrin ...

  6. Java学习笔记--继承和多态(上)

    1.通过继承来开发超类(superclass) 2.使用super 关键词唤起超类的构造方法 3.在超类中覆盖方法 4.区分override和overload 5.在Object类中探索toStrin ...

  7. java学习笔记-继承中super关键字

    背景: 在java继承的概念中我们得知,被声明为私有的类成员对所属的类来说仍然是私有的.类之外的任何代码都不能访问,包括子类. super关键字的两种用法: 1.用于调用超类的构造函数: 2.用于访问 ...

  8. Java学习笔记——继承、接口、多态

    浮点数的运算需要注意的问题: BigDecimal operand1 = new BigDecimal("1.0"); BigDecimal operand2 = new BigD ...

  9. JAVA学习<六>

    1.Java中的局部变量和成员变量: 2.变量同名,优先方法的局部变量. 3. 4.构造方法: 5.Java 中的 static 使用之静态变量: Java 中被 static 修饰的成员称为静态成员 ...

随机推荐

  1. DRF的限流功能

    限流,可以对接口访问的频次进行限制,以减轻服务器压力. 全局配置 在settings.py上添加 REST_FRAMEWORK = { 'DEFAULT_THROTTLE_CLASSES': ( 'r ...

  2. java Class.forName()

    Java程序在运行时,Java运行时系统一直对所有的对象进行所谓的运行时类型标识.这项信息纪录了每个对象所属的类. 虚拟机通常使用运行时类型信息选准正确方法去执行,用来保存这些类型信息的类是Class ...

  3. 华为MateBook笔记本对比微软Surface Pro 4,谁更好?

    继上网本.超极本等概念之后,变形本和二合一设备逐渐升温,今年终于整体爆发,继苹果的iPad Pro.微软的Surface Pro 4之后,华为推出了自己的第一部电脑产品同时也是二合一设备的华为Mate ...

  4. AC日记——[HEOI2012]旅行问题 bzoj 2746

    2746 思路: 建立ac自动机,然后把fail树抽出来: 然后在fail树上走lca(神奇): 代码: #include <cstdio> #include <vector> ...

  5. php判断检测一个数组里有没有重复的值

    php判断检测一个数组里有没有重复的值 php里有一个处理数组重复值得函数array_unique,我们的思路就是用这个函数来实现的. if (count($array) != count(array ...

  6. 【转+整理】jenkins与SonarQube集成

    一.SonarQube 我的理解是,SonarQube就是一个对代码进行分析的平台,其功能可以通过插件扩展.支持多种语言,也支持静态代码检查.发现潜在bug等. 以下是参考信息: 维基百科:https ...

  7. python formatters 与字符串 小结 (python 2)

    最近学习python 2 ,觉得有必要小结一下关于字符串处理中的formatters, 转载请声明本文的引用出处:仰望大牛的小清新 0.%进行变量取值使用的时机 在python中,如果我们只是需要在字 ...

  8. 51nod 1129 字符串最大值

    首先我们可以想到的是,既然求的是前缀的长度,就意味着一定是从1开始的,那么我们可以直接用下 标表示每一个前缀.但是可能存在几个前缀互相包含的情况,比如:abababa我们可以看见的是aba中包含着ab ...

  9. 软Raid5,LVM,3T大硬盘纠缠操作的问题

    新服务器,4块3T大硬盘,软Raid5 组建 加上LVM分区各种一通操作... 悲催的是经过4天的软raid rebuild,最终状态给我FAIL了,当看到raid的state[ State : cl ...

  10. JVM加载Class文件的机制

    1.Java中的所有类,必须被装载到jvm中才能运行,这个装载工作是由jvm中的类装载器完成的, 类装载器所做的工作实质是把类文件从硬盘读取到内存中 2.java中的类大致分为三种:     1.系统 ...