【java】兴唐第二十五节课(异常和log4j的使用)

2024-05-01 05:32

本文主要是介绍【java】兴唐第二十五节课(异常和log4j的使用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


异常
1、try catch finally语法(附带多重catch)
代码实现:

public static void main(String[] args) {try {int i = 1/0;}catch(ArithmeticException e){System.out.println("出现数学运算异常:" + e);}catch(ArrayIndexOutOfBoundsException e) {System.out.println("出现数学运算异常:" + e);}finally{int i = 3/3;}}

注:
(1)try必须出现,catch和finally至少出现一个。
(2)多重catch时必须先子类异常后父类异常否则报错。
(3)try的使用我们只将可能发生异常的代码放入try,并尽量最小化,方便找到出错的位置。

public static void main(String[] args) {try {int i = 1/0;}catch(Exception e) {}catch(ArithmeticException e){System.out.println("出现数学运算异常:" + e);}catch(ArrayIndexOutOfBoundsException e) {System.out.println("出现数学运算异常:" + e);}finally{int i = 3/3;}}

如上述程序便会出现错误
因为Exception是后面两个类的父类
(3)无论异常与否,finally里的代码都要被执行。

2、final、finally和finalize的区别:
final:修饰类、方法和变量

finally:如上

finalize:方法名,该方法在垃圾收集器将对象从内存中清除之前做必要的清理工作
代码实现:

public class FinalizeDemo {@Overrideprotected void finalize() throws Throwable {super.finalize();System.out.println("对象从内存中清除之前执行");}public static void main(String[] args) {new FinalizeDemo();System.gc();}
}

注:
(1)调用gc方法提醒jvm清理内存,但不一定就会将上述代码中的对象清除,因为jvm垃圾处理的机制是达到一定伐值之后才会进行回收。
(2)@Override 代表的是重写父类方法。
(3)jvm开始清理内存后会调用finalize方法。

3、例题

public class ThrowDemo {private static int i ;public static void main(String[] args) {System.out.println(c(i));}public static int c(int i) {try {return i;}finally {i++;System.out.println(i);//return i;}}
}

输出结果为
1 0
注:
(1)尽管已经return了,但finally的程序依然要执行。
(2)i值尽管在finally中有改变,但时return的值不会变。
(3)如果将注释的那行代码写入程序,则返回值是1,也就是说如果返回两个值则会发生覆盖,但一般不这么写。

4、异常的抛出:
(1)throw
1)throw用于抛出具体异常类的对象,一般用于方法体中。

2)抛出异常的目的是将异常放到同一个地方去捕获,比如说一个try里放好几个方法,然后将异常一起进行捕获。
代码实现:

public class ThrowDemo {public static void ThrowTest() {try {int i = 1/0;}catch(RuntimeException e) {throw(e);}}public static void main(String[] args) {try {ThrowTest();}catch(RuntimeException e) {System.out.println("运行时出现异常!!!");}}
}

(2)throws
1)抛出的是方法的类,写在方法的声明上。

2)如果方法整个都有可能出错,我们就不捕获了,直接在方法上标注出方法可能发生异常(用throws)

3)使用方法
代码实现:

public static void ThrowTest1() throws Exception{String[] str = new String[5];str[6] = "";}

4)如果使用了throws的方法就不能直接调用了,必须进行处理,可以用try catch进行捕获,可以将调用该方法的方法也抛出去。

5、hrow关键字一般用在方法体中,也可以用在代码块中,但如果代码块中抛出的异常对象是由检查时异常创建的,则必须使用try-catch进行处理。
注:
捕获时catch的异常的范围必须大于等于抛出的异常的范围
如:

try {ThrowTest();ThrowsTest();}catch(RuntimeException e) {System.out.println("运行时出现异常!!!");}

会报错,因为ThrowsTest();抛出的是Exception而catch只能捕获RuntimeException。

PPT上的知识点
1、当出现异常时会中断程序运行。
2、异常(Exception)可分为运行时异常和检查时异常
3、常见异常:
Exception: 异常类的根类
RuntimeException: 运行时异常类的基类
ArithmeticException: 算术错误情形,如以零作除数
ArrayIndexOutOfBoundException: 数组大小小于或大于实际的数组大小
NullPointerException : 尝试访问 null 对象成员
ClassNotFoundException : 不能加载所需的类
NumberFormatException: 数字转化格式异常,字符串到 float 转换无效
IOException I/O : 异常的根类
FileNotFoundException : 找不到文件
SQLException : 数据库访问异常
InterruptedException : 线程被中断异常
4、java中对异常的处理方法:
(1)通过try、catch和finally捕获异常
(2)通过throw或throws关键字抛出异常

log4j
1、简介
(1)Log4j是Apache的一个开放源代码项目
(2)将日志信息输出到控制台、文件等地方
(3)控制日志输出格式
(4)控制使java代码更方便

2、log4j的三大组件

(1)logger(日志类别):DEBUG、INFO、WARN、ERROR、FATAL
(2) Appender(日志输出目的地)
(3)Layout(格式化输出日志信息)

3、level是日志记录的优先级:ERROR、WARN、INFO、DEBUG(由高到低)

4、需要在类中定义一个 变量log
代码实现:

private static final Logger log = Logger.getLogger(Log4jDemo.class);  
//记住了就行       

注:
(1)添加类的原因:在打印日志时需要标识出这个信息来自哪个类。

5、日志信息的打印
代码实现:

public class Log4jDemo {private static final Logger log = Logger.getLogger(Log4jDemo.class);         public static void main(String[] args) {//debug是调试程序细节日志log.debug("这是debug信息");//info打印业务逻辑log.info("这是info信息");//warn表示打印警告信息log.warn("这是warn信息");//error打印错误信息log.error("这是错误信息");}}

6、log4j.properties分析
(1)log4j.properties不能错一个字母!需要放到src目录

(2)

log4j.rootCategory=DEBUG, file, stdout

其中log4j.root是定义的名称

(3)

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

其中Console指的是输出到控制台

(4)
老师给的文件中的

log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File=target/test.log
log4j.appender.file.MaxFileSize=5120KB
log4j.appender.file.MaxBackupIndex=10 
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d-[TS] %p %t %c - %m%n

1)一个每天滚动的日志:即每天只产生一个日志文件
2)限制:每一个文件最多每天5120KB、最大记录文件数为10个

6、Appender
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件,如果使用该配置方法,则会一直产生文件直到内存占满)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

7、Layout
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
这个比较有(hao)用 (wan),要学会怎么配置
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
注:如果在死循环下面写的语句不仅不能运行而且会报错。

8、
更改输出格式
原代码如图

log4j.appender.stdout.layout.ConversionPattern=%d-[TS] %p %t %c - %m%n

其中含义:
%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%r: 输出自应用启动到输出该log信息耗费的毫秒数
%c: 输出日志信息所属的类目,通常就是所在类的全名
%t: 输出产生该日志事件的线程名
%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中
%%: 输出一个"%“字符
%F: 输出日志消息产生时所在的文件名称
%L: 输出代码中的行号
%m: 输出代码中指定的消息,产生的日志具体信息
%n: 输出一个回车换行符,Windows平台为”\r\n",Unix平台为"\n"输出日志信息换行

9、properties自动将中文改为UFT-8的格式

10、log4j.logger.包名:
表示此包下的类日志输出的级别,不跟随第一行的范围。

这篇关于【java】兴唐第二十五节课(异常和log4j的使用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950821

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程