Java读书笔记一(异常处理)
1.介绍
在开发过程中。都会遇到程序执行时的异常,比如逻辑错误、硬件故障等,本篇博客将会具体的介绍一下Java中的异常处理机制。
2.Try和Catch捕获异常
我们在处理异常过程中经经常使用到的就是Try和Catch语句了。try语句块可以指出可能出现的异常,随后通过一个或者多个Catch语句块来捕获。
2.1.简单的Try和Catch语法
package com.RuntimeException; public class Sample11_1
{
public static void main(String[] args)
{
//被监视的代码块
try
{
//创建数组对象
int[] a=new int[4];
System.out.println("整型数组创建完成! ! ");
//訪问数组元素
a[3]=9;
System.out.println("整型数组中第四个元素的数值为"+a[3]+"!!!");
}
//处理下标越界异常
catch(ArrayIndexOutOfBoundsException aiobe)
{
//打印提示信息
System.out.println("这里出现的错误类型是:数组下标越界。。");
}
//处理空引用异常
catch(NullPointerException npe)
{
//打印提示信息
System.out.println("这里出现的错误类型是:空引用! !");
}
System.out.println("主程序正常结束! !! ");
}
}
2.2.异常的传播过程
在异常的传播过程中,假设没有Catch语句进行捕获的话,异常将会沿着方法的调用栈一直向上传播。
假设传播的过程中一直没有Catch语句块捕获的话,则终于传播到main方法中。最后由Main方法进行抛出,由java执行时的环境来处理。
package com.RuntimeException; import java.io.IOException;
import java.net.ServerSocket; public class Sample11_2 { public static void main(String[] args) { // 主方法中调用method1方法
method1();
} static void method1() {
// method1方法中调用method2方法
method2();
} static void method2() {
int[] a = new int[3];
// 产生数据下标越界错误
a[4] = 12;
System.out.println("OK!!!");
} }
2.3.finally语句块的作用
某些特殊情况下,当程序出错后,不管抛出异常与否都必须保证运行。比如。打开了一个数据库连接。不管处理过程中是否抛出异常,最后都要关闭连接。不能因为抛出异常就影响了其运行。那么此时能够把必需要运行的语句放置到finally中。
package com.RuntimeException; public class Sample11_3 { public static void main(String[] args)
{
//受监视的代码块
try
{
//创建长度为4的int型数组
int[] a=new int[4];
System.out.println("整型数组创建完成!! ");
//为数组最后一个元素赋值
a[3]=9;
System.out.println("整型数组中第四个元素的数值为"+a[5]);
}
//处理空引用异常代码块
catch(NullPointerException npe)
{
//打印提示信息
System.out.println("这里出现的错误类型是:空引用! !");
}
//finally块
finally
{
//打印提示信息
System.out.println("这里是finally块。不管是否抛出异常,这里总能运行! ");
}
}
}
2.4.try、catch以及finally之间须要注意的问题
~没有catch的情况下。finally必须紧跟try
~catch和finally不能同一时候省略
~try、catch以及finally块之间不能插入其它代码
3.异常的层次结构
当发生异常的时候。java会将异常包装成一个异常类的对象,并将其引用作用參数传递给对应的catch语句来处理。在java中异常分为两部分捕获异常和未捕获异常
3.1.异常层次图
~Throwable类有两个直接子类,Error与Exception类,Exception类有一个子类RuntimeException。
~捕获异常一般都是由外界因素产生,而且是能够恢复的,并非由程序引起的,这些异常程序本身没有问题也可能会产生。
~未捕获异常,即Error类以及其子类以及RuntimeException类及其子类
~捕获的异常类型,都须要在程序中进行捕获处理。
3.2.异常的显性再抛出
对于捕获的异常,在方法声明时抛出后。能够在当中通过Try以及Catch再次抛出。
package com.RuntimeException; import java.io.IOException;
import java.net.ServerSocket; public class Sample11_10 {
// 定义connect方法将有可能抛出IOException异常
public void connect() throws IOException { // 受监视的代码
try {
// 创建ServerSocket对象
ServerSocket ss = new ServerSocket(9999);
}
// 异常处理代码
catch (IOException e) {
// 将异常抛出
throw e;
}
}
}
3.3.隐形再抛出
假设仅仅是想把异常再抛出的话,不必使用显性再抛出,直接使用隐形再抛出就可以。
package com.RuntimeException; import java.io.IOException;
import java.net.ServerSocket; public class Sample11_12 {
//声明方法myFunction将有可能抛出IOException异常
public static void myFunction() throws IOException
{
//创建ServerSocket对象
ServerSocket ss=new ServerSocket(9999);
}
public static void main(String[] args)
{
//受监视的代码
try
{
//调用myFunction方法
myFunction();
}
//异常处理代码
catch(IOException e)
{
//打印调用栈信息
e.printStackTrace();
}
System.out.println("恭喜你。程序正常执行结束!!! ");
}
}
4.自己定义异常类
我们也能够自己定义自己的异常类来满足自己使用时的需求。
4.1.创建自己定义异常类
一般创建自己定义异常类的话,仅仅需继承Exception或者其它捕获异常类,经常使用到的方法例如以下
~printStackTrace():该方法将在控制台打印异常调用栈的信息
~toString():该方法将返回该异常对象的字符串表示
~getMessage():返回异常中携带的出错信息。
package com.RuntimeException;
class MyException extends Exception
{
//两种版本号的构造器
public MyException()
{ }
public MyException(String msg)
{
super(msg);
}
}
//主类
public class Sample11_15
{
public static void main(String[] args)
{
//创建自己定义异常类对象
MyException me=new MyException("自己定义异常类");
me.printStackTrace();
//调用继承的方法
System.out.println("自己定义异常对象的字符串表示为:“"+me.toString()+"”。 ");
System.out.println("自己定义异常对象携带的出错信息为:“"+me.getMessage()+"”。");
}
}
4.2.同一时候捕获多次异常
假设try语句后要跟多个catch的话,最后catch语句的先后顺序满足从小到大的范围进行捕获,也就是异常先从子类開始。慢慢的递增。
Java读书笔记一(异常处理)的更多相关文章
- Thinking In Java读书笔记--对象导论
Thinking In Java读书笔记--对象导论[对象]服务提供者==>将对象看做一个服务提供者[程序员分类][类创造者]/[客户端程序员] [访问控制存在的原因?][1]客户端程序员无法触 ...
- head first java读书笔记
head first java读书笔记 1. 基本信息 页数:689 阅读起止日期:20170104-20170215 2. 标签 Java入门 3. 价值 8分 4. 主题 使用面向对象的思路介绍J ...
- think in java 读书笔记 3 —— 数据报
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 概要 1. 数据报基本知识 2 ...
- think in java 读书笔记 2 —— 套接字
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 概要 1. 套接字基本知识 2 ...
- think in java 读书笔记 1 ——移位
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 在Think in Java中 ...
- Java读书笔记1
Java逍遥游记读书笔记 前言 必须先来一句,这是入门级别,高手勿喷~ 写Android的时候总有一些语句不是很理解,其实大部分是Java的内容,所以想系统的学下Java. 这本书——<Java ...
- java读书笔记二
这是我的一些读书笔记: 我研究了一下面向对象: 面向对象符合人类看待事物的一般规律,对象的方法的实现细节是包装的,只有对象方法的实现者了解细节 我觉得面向过程是由过程.步骤.函数组成,过程是核心,面向 ...
- Effective Java读书笔记完结啦
Effective Java是一本经典的书, 很实用的Java进阶读物, 提供了各个方面的best practices. 最近终于做完了Effective Java的读书笔记, 发布出来与大家共享. ...
- 【java读书笔记】——java的异常处理
程序在实际环境的执行过程中.安全成为须要首先考虑的重要因素之中的一个.这也是用户和程序猿最关心的问题.同一时候,Java语言健壮性也体如今了可以及时有效地处理程序中的错误.准确的说是Java的异常处理 ...
随机推荐
- 小记如何有顺序的搭建一个Spring的web项目
如何有顺序的搭建一个Spring的web项目 一.新建一个简单的maven,war工程 eclipse下如有报错,右键 Deployment 单击 Generate 生成web.xml后可解决报错 二 ...
- 学一下HDFS,很不错(大数据技术原理及应用)
http://study.163.com/course/courseMain.htm?courseId=1002887002 里面的HDFS这一部分.
- Bing地图切片原理
Bing地图切片系统 Bing地图提供了一个可以直接平移和缩放的世界地图.为了让地图操作更加平滑和及时响应,我们选择提前渲染地图不同层级的细节,并把每个层级的地图切割成为瓦片以便快速的还原展示.这篇文 ...
- hdu 4628 Pieces(状态压缩+记忆化搜索)
Pieces Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total S ...
- c语言运算符优先级与while循环案例
sizeof可以获取数据类型的内存中的大小(字节) #include <stdio.h> #include <stdlib.h> // standared 标准 // inpu ...
- zzulioj--1715--土豪银行(贪心)
1715: 土豪银行 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 456 Solved: 123 SubmitStatusWeb Board ...
- nyoj--586--疯牛(二分&&枚举)
疯牛 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 农夫 John 建造了一座很长的畜栏,它包括N (2 <= N <= 100,000)个隔间,这些小隔间 ...
- TCP、HTTP协议的RPC
TCP.HTTP协议的RPC 1.1 基于TCP协议的RPC 1.1.1 RPC名词解释 RPC的全称是Remote Process Call,即远程过程调用,RPC的实现包括客户端和服务端,即服务调 ...
- (二)Ribbon(负载均衡的客户端)+Rest
前面讲了服务的注册与发现,微服务项目会把项目的各个业务需求划分成几个模块来单独提供服务,各服务间的调用都是采用Http Restful来实现,但是在SpringClound中服务间的调用有两种方式:一 ...
- xBIM 高级03 更改日志创建
系列目录 [已更新最新开发文章,点击查看详细] 模型中发生的每一个变化都是事务的一部分,这是我们设计的核心.所有事务都是由 IModel 的实现创建的,并且从中被弱引用,因此当使用 using ...