【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.包名:
表示此包下的类日志输出的级别,不跟随第一行的范围。
相关文章:

CentOS 命令提示符颜色及样式详解
命令提示符:prompt CentOS下查看当前命令提示符格式: 1 [rootlocalhost ~]# echo $PS1 #显示当前使用的PS1样式 2 [\u\h \W]\$ 命令提示符参数如下: \d :#代表日期,格式为weekday month date,例如&#…

Max_user_connections 与Max_connections 与max_connect_errors
对于连接数的设置,show variables里有三个参数可以对它进行控制,max_connections与max_user_connections以及max_connect_errors。下面对这三个参数相关描述。 max_connections:针对所有的账号所有的客户端并行连接到MYSQL服务的最大并行连接…

压力变动力,存储追求高效率
企业的数据存储量每年都要大幅增长,但是IT预算呈现紧缩趋势。这就是企业面临的最大存储难题,即如何平衡数据增长与提高存储利用率和降低成本之间的关系。 非结构化数据带来的难题 存储最直接的压力来自于不断增长的数据量。今天,我们面对的是…

Hadoop学习之路(三)Hadoop-2.7.5在CentOS-6.7上的编译
下载Hadoop源码 1、登录官网 2、确定你要安装的软件的版本 一个选取原则: 不新不旧的稳定版本 几个标准: 1)一般来说,刚刚发布的大版本都是有很多问题 2)应该选择某个大版本中的最后一个小版本 阅读编译文档 1、准备一…

static String valueOf(XXX xxx)
1 package day01;2 /**3 * static String valueOf(XXX xxx)4 * 字符串提供了一组静态的重载的valueOf方法,作用5 * 是将其他类型转换为字符串6 * author ta7 *8 */9 public class Demo10 { 10 public static void main(String[] args) { 11 int a 123; 12 …

【java】兴唐第二十五节课小程序学生卡转账小系统(自己写的异常)
1、StuCard.java public class StuCard {public static void TransMoney(int source, int money, int target) {money - target;if(money < 0) {throw new NotEnoughMoneyException("余额不足");}System.out.println("商家的余额为:" sour…

【JQUBAR1.1】jQuery 插件发布
【JQUBAR1.1】jQuery 插件发布 JQUBAR1.1 简介 2010-11-22在博客园发布了柱状图JQUBar1.0 jQuery 插件。现将该插件升级为1.1版本。 1.1版本修复了部分bug,同时新增以下功能: 1.可自定义坐标颜色 2.可自定义X,Y轴坐标名称 3.Y轴动态坐标自动建立 4.Y…

ssh远程操作服务器
登录方式 ssh account192.168.xxx.xxx 输入密码 远程上传下载文件 上传: scp filepath acount192.168.xxx.xxx:path filepath为要上传的文件路径path为上传到服务器的储存路径 下载: scp acount192.168.xxx.xxx:filepath path filepath为要下载的文件路径…

【java】兴唐第二十三节课作业
已知如下: 下表为某班级四次考试成绩单, 要求使用HashMap<String, Integer>存储每次考试的成绩(key键为姓名,value为成绩)。要求使用LinkedList存储考试次数,有几次考试就有几个HashMap注意…

Data - 数据思维 - 中篇
6 - 模型与框架 利用现有的成熟的理论、模型与框架,结合实际业务情况,搭建分析框架,尽量确保数据分析维度的完整性,结果的有效性及正确性。 营销理论模型:4P、用户使用行为、STP理论、SWOT等。管理理论模型:…

快速设置戴尔latitude笔记本的触摸板和指点杆
// TouchPadSettings.cpp : Defines the entry point for the console application.// by windviki 2010/08/31// 转载请注明出处。//// 办公用的戴尔笔记本除了触摸板,还在键盘中间有一个指点杆(point stick)// 打字很不习惯,经常…

Ubuntu 10.10系统安装手记
原来一直在公司用Ubuntu,感觉做开发是相当不错的,特别那种各种利用命令的方式真是太高效了。所以现在想把笔记本也装上,弄了半天,也遇到不少问题,记下来备忘一下。 虚拟机还是双系统 磁盘里面好多东西,基本…

php值传参,引用传参以及对象传参
传值:是把实参的值赋值给行参 ,那么对行参的修改,不会影响实参的值传引用 :真正的以地址的方式传递参数传递以后,行参和实参都是同一个对象,只是他们名字不同而已对行参的修改将影响实参的值说明࿱…

用一行代码高效的求一个列表的平方和
最近看到一个笔试题,考察的都是 Python 中的高阶函数 题目如下:用一行代码高效的求一个列表的平方和(不能用 sum 函数) 分析 1.先将列表中每个值作平方: 立即想到 map 函数,假设列表是 range(10),那么这个列表中平方是…

【java】第二十二节课(HashSet)
1、使用HashSet建立对象、添加元素并使用两种方法遍历 代码实现 public class SetDemo {public static void main(String[] args) {Set<String> set new HashSet();set.add("猴子");set.add("八戒");set.add("唐僧");set.add("沙僧…

转:在 .NET 中实现异步回调访问数据库
在 .NET 中实现异步回调访问数据库 时间:2009-11-17 19:52来源:网络收集 作者:佚名 点击: 334 次 技术论坛某些场合下,在对数据库进行访问时,为了避免同步访问数据时所带来的延迟,我们需要改进设计,以提高程序执行效率。一方面&am…

《资安人》:迈向成功SOC之路
近日,台湾的《资安人》上发表了一篇文章——《迈向成功的SOC之路》,现转载至此,以飨读者。【作者:王榮信 -11/08/2010】在現代虛擬世界中,造成資訊安全事件的來源為病毒、蠕蟲或木馬,不變的安全事件來源就是…

Laravel 上使用 phpexcel的两种方式
原创 2017年06月24日 20:24:311229文章采集与网上 方式1。使用原生的phpexcel , http://blog.csdn.net/CSwfe/article/details/52748046?locationNum1 1、在app目录下创建一个新的文件夹,命名libs(可自定义) app/libs/phpExcel2…

剑指offer-----Python-----栈
用两个栈实现队列 题目:用两个栈来实现一个队列,完成队列的Push和Pop操作。队列中元素为int类型. 首先,栈都是先进后出,但是队列呢,一般是先进先出。也就是创建两个栈stack1和stack2,使用两个“先进后出”的…

【工具软件】markdown编译器待办事项无法打勾
使用时可以直接点击上方工具栏的 List item 注意:此时已经自动在里面加了一个空格,如果直接加x的话,不会打勾,如下:[ x] List item 所以先删除空格在加x 问题解决

【转】创建不可见的Activity
在android开发中有时候会用到一些后台的Activity,但又不适合使用service,比如直接点击程序图标时只是执行一段代码,不需要弹出程序界面。此时可以在项目的AndroidManifest.xml文件中相应的Activity标签中添加这样一行:android:the…

关于 TApplication 详解 三 ---- TComponent
ComponentCount属性 对应对象:所有组件 声明:property ComponentCount: Integer; 功能:此属性在运行时有效,它是只读型。同时它标明组件具有的组件数。当用户在设计时可以在窗体上放置一个组件,因此此窗体将变为…

[转载] K3 K3c 最简单无损开壳方法
只用一把螺丝刀就行了,其它什么撬棒 信用卡 撬片等 拆机工具一概不用。拆了5台,只有一台断了一个扣口。1. 把底部4个螺丝拿掉。2.把路由如图放在桌子上,路由平行于身体,注意是立着放 使路由与桌子接触的部分成30度角。这样使一侧…

图像处理随笔知识
采样频率: 采样频率是指1s内采样的次数,反映了采样点之间的间隔大小。 采样频率越高,得到的图像样本越逼真,图像质量越高,但要求的存储量也越大。 图像量化: 要用多大范围的数值来表示图样采样之后的每一个…

一则android软件开发工程师的招聘信息
岗位职责: 从事Android平台的客户端软件开发 任职资格: 1、一年以上Android平台开发经验; 2、两年以上Java开发经验; 3、熟悉Android开发架构和API调用; 4、熟悉HTTP、TCP/IP通讯协议; 5、熟悉面向对象编程…

【数据库】数据库基本操作
操作练习: 创建数据库 删除数据库 修改数据库配置 创建数据表 修改表结构 ———————————— 添加字段 修改字段 重命名字段 更改主键 删除字段 ———————————— 重命名表名 删除表 截断表 表数据的操作 添加数据 修改数据 删除数…

USERADD命令详解
2019独角兽企业重金招聘Python工程师标准>>> 1.作用useradd命令用来建立用户帐号和创建用户的起始目录,使用权限是终极用户。2.格式useradd [-d home] [-s shell] [-c comment] [-m [-k templat…

tensorflow入门(二)
import numpy as np import tensorflow as tf import matplotlib.pyplot as plt#使用numpy生成200个随机点 x_data np.linspace(-0.5,0.5,200)[:,np.newaxis] noise np.random.normal(0,0.02,x_data.shape) y_data np.square(x_data) noise#定义两个placeholder x tf.plac…

DRF序列化和反序列化
一、自定义序列化组件 新建一个任意名的py文件,里面导入serlizerfrom rest_framework import serializers自定义一个类继承serializers,里面写需要序列化的字段方法一:继承serializers.Serializerclass BookSerlizer(serializers.Serializer)…

设计模式学习笔记-中介模式
概述: 用中介对象来封装一系列的对象交互。中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以对立地改变他们之间的…