Java基础学习补充 -- 异常处理和log4j日志

Java中的异常处理

异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。

Java中所有异常的基类Throwable:Throwable又分为Error类和Exception类。

错误:Error类以及他的子类的实例,代表了JVM本身的错误。错误不能被程序员通过代码处理,Error很少出现。

异常:Exception以及他的子类,代表程序运行时发送的各种不期望发生的事件。可以被Java异常处理机制使用。Exception又分为检查时异常和运行时异常(RuntimeException)

检查性异常:最具代表的检查性异常是用户错误或问题引起的异常,这是程序员无法预见的。

运行时异常: 运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。

Java中的异常分为运行时异常和检查时异常,运行时异常表示RuntimeException以及子类,这些异常无需在程序中进行捕获,大多可以通过代码进行控制避免,检查时异常包过除运行时异常表示RuntimeException以及子类以外其他所有异常,这些异常需要在程序中进行捕获处理。

异常捕获

1.使用:使用 try/catch 关键字可以捕获异常。try/catch 代码块放在异常可能发生的地方。使用Try捕获可能出现异常的代码,使用catch块进行不同异常操作的处理,当try块中的程序出现异常时,将进入对应的catch代码块进行操作,而不再执行try块中剩余的代码。

使用try/catch捕获异常后,如果程序出现异常,将不会阻断程序的运行。

2.写法:

try{
   // 可能出现异常的代码块
}catch(ExceptionName1 e1){
   //Catch块
}catch(ExceptionName1 e2){
//Catch块
}

注意:一个 try 代码块后面跟随多个 catch 代码块,一般最后使用Exception作为结束,表示捕获所有异常,但是如果要使用多个catch,那么Exception异常就不能放在要捕获的具体异常之前。

3.常用方法:e1.printStackTrace():打印堆栈信息;e1.getMessage():获得错误信息

try/catch如果需要确保程序能够不被中断,必须确保catch快能够捕获程序中可能出现的所有异常

finally:表示无论程序是否出现异常,哪怕try中出现了return语句,也必须执行完finally才能结束当前方法。

finally块不管异常是否发生,只要对应的try执行了,则它一定也执行。只有一种方法让finally块不执行:System.exit()。因此finally块通常用来做资源释放的操作:如关闭I/O流,关闭数据库连接等等。

try{
  // 程序代码
}catch(异常类型1 异常的变量名1){
  // 程序代码
}catch(异常类型2 异常的变量名2){
  // 程序代码
}finally{
  // 程序代码
}

注意:一个try至少要有一个catch块,否则, 也要至少要有1个finally块,才能构成一个捕获异常的语句。

抛出异常

如果一个方法出现了异常而没有捕获(检查性异常),那么该方法必须使用 throws 关键字来声明,将异常抛出,抛出后,由调用该方法的地方进行捕获异常,如果不想捕获可以继续抛出。原则上,在main方法中如果出现了异常,不建议再抛出,如果抛出,则可能导致程序无法正常运行。
throws 关键字放在方法名的尾部,如果抛出多个异常,异常之间使用逗号分割。

也可以使用 throw 关键字抛出一个异常,即,在程序中手动抛出异常,无论它是新实例化的还是刚捕获到的。

如果使用throw抛出的是一个检查型异常,那么必须使用throws抛出声明,如果使用throw抛出的是一个运行时异常,那么不必再使用throws进行抛出声明。

自定义异常

自定义异常类,必须基础现有的异常类
通常继承Exception 或者 RuntimeException,分别表示声明了一个检查时异常和一个运行时异常。
并且重写其getMessage()方法。

Log4j日志的使用

log4j的使用:
1、导入log4j.jar
2、在src同级下创建log4j.propetites配置文件
3、在需要打印日志的类中通过Logger.getLogger()拿到一个日志对象
4、分别调用不同局级别的打印语句,进行日志的输出

log4j的配置文件的设置:http://www.blogjava.net/zJun/archive/2006/06/28/55511.html

 1 public class Demo03_log4j {
 2
 3     /**
 4      * 通过Logger.getLogger拿到log对象,参数传入本类的class
 5      *
 6      * log4j的使用:
 7      *        1、导入log4j.jar
 8      *        2、在src的目录下(与包同级)创建log4j.propetites配置文件
 9      *        3、在需要打印日志的类中通过Logger.getLogger()拿到一个日志对象
10      *        4、分别调用不同局级别的打印语句,进行日志的输出
11      */
12     static Logger log = Logger.getLogger(Demo03_log4j.class);
13
14     public static void main(String[] args) {
15         //打印一条错误信息
16         log.error("打印一条错误信息");
17         //打印一条警告信息
18         log.warn("打印一条警告信息");
19         //打印一条info信息
20         log.info("打印一条info信息");
21         //打印一条测试信息
22         log.debug("打印一条测试信息");
23     }
24 }

原文地址:https://www.cnblogs.com/JiangLai/p/8905844.html

时间: 2024-10-17 19:04:23

Java基础学习补充 -- 异常处理和log4j日志的相关文章

java基础学习总结——流

永不放弃,一切皆有可能!!! 只为成功找方法,不为失败找借口! java基础学习总结——流 一.JAVA流式输入/输出原理 流是用来读写数据的,java有一个类叫File,它封装的是文件的文件名,只是内存里面的一个对象,真正的文件是在硬盘上的一块空间,在这个文件里面存放着各种各样的数据,我们想读文件里面的数据怎么办呢?是通过一个流的方式来读,咱们要想从程序读数据,对于计算机来说,无论读什么类型的数据都是以010101101010这样的形式读取的.怎么把文件里面的数据读出来呢?你可以把文件想象成一

Java基础学习总结——Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

java基础学习——19、String类

之前的Java基础系列中讨论了Java最核心的概念,特别是面向对象的基础.在Java进阶中,我将对Java基础进行补充,并转向应用层面. 大部分编程语言都能够处理字符串(String).字符串是有序的字符集合,比如"Hello World!".在Java中,字符串被存储为String类对象.调用字符串对象的方法,可以实现字符串相关的操作. String类包含在java.lang包中.这个包会在Java启动的时候自动import,所以可以当做一个内置类(built-in class).我

java基础学习总结——线程(一)

永不放弃,一切皆有可能!!! 只为成功找方法,不为失败找借口! java基础学习总结——线程(一) 一.线程的基本概念 线程理解:线程是一个程序里面不同的执行路径 每一个分支都叫做一个线程,main()叫做主分支,也叫主线程. 程只是一个静态的概念,机器上的一个.class文件,机器上的一个.exe文件,这个叫做一个 进程.程序的执行过程都是这样的:首先把程序的代码放到内存的代码区里面,代码放到代码区后并没有马上开始执行,但这时候说明了一个进程准备开始,进程已 经产生了,但还没有开始执行,这就是

Linux运维系统工程师与java基础学习系列-2

Java天生骄傲系列-2 运算符 1.   算术运算符 注: 1)"+"号除了用于加法运算以外,还用作字符串连接符: 2)字符串数据和任何数据使用+都是相连接,最终都会变成字符串. package day4javatest.myeclipse;         publicclass day4test1 { /** * @param args */ publicstaticvoid main(String[]args) { // TODO Auto-generated method s

JAVA基础学习流程

JAVA基础学习: 第一步:学习JAVA的开发环境配置.开发第一个Java程序.也建议大家开始使用eclipse等IDE,不必纠结是不是一定要从记事本开始. 第二步:学习数据类型.运算符.变量.这是编程的基础,是程序的“砖块”.这些内容大多数编程语言都有,而且非常类似. 第三步:学习控制语句.这是编程的基础,是程序的“混凝土”.有了控制语句+变量,理论上你就可以写任意的程序了.因此,这是进入程序的门槛,需要大量的练习. 第四步:学习面向对象基础.通过类.对象.包等基本概念讲解.学习的时候,一定要

Java基础学习191221(可变参数,数组,Array类,稀疏数组,继承重写多态,抽象类,接口)

Java基础学习 可变参数 在方法声明中,在指定参数类型后加一个省略号(...). 一个方法中只能指定一个可变参数,它必须是方法的最后一个参数.任何普通参数都必须在它之前声明. public class printMax { public static void main(String[] args) { printMax(1,5,8,78,415,15); } public static void printMax( double... numbers){ if (numbers.length

Java基础学习——数组初识(1)

Java基础学习--数组初识(1) 1什么是数组 Java中常见的一种数据结构就是数组,数组可以分为一维数组.二维数组和多维数组. 数组是由一组相同的变量组成的数据类型,数组中每个元素具有相同的数据类型,数组中的每个元素都可以用一个统一的数组名和下标来确定. 2 数组的使用 数组的一般使用步骤: 声明数组 分配内存给该数组 下面是一维数组为例: 数据类型  数组名 []: 数组名 = new 数据类型 [数据个数]: 2.1一维数组的声明与赋值 1.数组的声明 int  num [];    

JAVA基础学习笔记(2)

看了几天的视频了,都没时间来写下学习笔记,今天来写下第二次的学习笔记,前几天看的给忘记了,就写最新看到的吧 主要内容:1.类的变量与函数(方法) 2.对象的存储方式 3.新建一个对象及对象的赋值与调用 4.空对象 5.匿名对象 1.类的变量与函数(方法) class Dog      //类名 { String name;  //变量的声明 int age; String color; void bark()   //方法的定义(返回值为空,不带参数) { System.out.println(