单元测试和日志技术

1.Junit使用的基本流程

<1>将junit的jar包导入到工程中
<2>编写测试方法该测试方法必须是公共的无参数无返回值的非静态方法在测试方法上使用@Test注解标注该方法是一个测试方法
<3>选中测试方法右键通过junit运行该方法
Junit点击下载

2.Junit常用的三个注解

测试注解【没有参数和返回值,要想测试返回值,则用该方法调用返回值方法即可】
@Before【Before运行在Test之前】
@Test【有两个则会执行两遍】
@After【After运行在Test之后】

public class Demo1 {@Test//测试注解[没有参数和返回值] 有两个则会执行两遍public void sum() {System.out.println("Test执行");}@Test//测试注解[没有参数和返回值]public void show2() {System.out.println("Test执行");}@Before//测试注解[没有参数和返回值]public void before() {System.out.println("Before运行在Test之前");}@After//测试注解[没有参数和返回值]public void after() {System.out.println("After运行在Test之后");}
}执行结果:
-------------------------------------------------------
Before运行在Test之前
Test执行
After运行在Test之后
Before运行在Test之前
Test执行
After运行在Test之后
3.Assert.assertEquals[断言、断点方法]
public class Demo1 {@Test//测试注解[没有参数和返回值] 有两个则会执行两遍public void sum() {System.out.println("Test执行");int sum = 10 + 20;//断言:测试结果和预期值是否一致Assert.assertEquals(sum,40);}@Before//测试注解[没有参数和返回值]public void before() {System.out.println("Before运行在Test之前");}@After//测试注解[没有参数和返回值]public void after() {System.out.println("After运行在Test之后");}
}运行结果:
-----------------------------------------------------
Before运行在Test之前
Test执行
After运行在Test之后java.lang.AssertionError: 
Expected :30
Actual   :40
4.Log4j设置日志

设置代码

public class Demo1 {//使用log4j的api来获取日志的对象//弊端:如果以后我们更换日志的实现类,那么下面的代码就需要跟着改//不推荐使用//private static final org.apache.log4j.Logger LOGGER = org.apache.log4j.Logger.getLogger(Demo1.class);//使用slf4j里面的api来获取日志的对象//好处:如果以后我们更换日志的实现类,那么下面的代码不需要跟着修改//推荐使用public static final Logger LOGGER = LoggerFactory.getLogger(Demo1.class);public static void main(String[] args) {//1.导入jar包//2.编写配置文件//3.在代码中获取日志的对象//Logger logger = LoggerFactory.getLogger(Demo1.class);// 4.按照日志级别设置日志信息/* LOGGER.debug("Debug级别的日志");LOGGER.info("info级别的日志");LOGGER.warn("warn级别的日志");LOGGER.error("error级别的日志");*/Scanner sc = new Scanner(System.in);System.out.println("输入一个整数");String number = sc.nextLine();//类型转换try {int result = Integer.parseInt(number);LOGGER.info("类型转换成功"+ result);}catch (NumberFormatException e){LOGGER.info("类型转换失败,请录入一个整数");}}
}//配置文件
log4j.rootLogger=INFO,my,fileAppender
#日志级别:OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者自定义的级别。
从左往右依次降低,默认是info 不会输出debug 和 all### direct log messages to my ###
# 往控制台输出
log4j.appender.my=org.apache.log4j.ConsoleAppender
# 立即刷新
log4j.appender.my.ImmediateFlush = true
# 打印流
log4j.appender.my.Target=System.err
# 日志输出模式可以灵活指定
log4j.appender.my.layout=org.apache.log4j.PatternLayout
# 日志输出模式细节
log4j.appender.my.layout.ConversionPattern=%d %t %5p %c{1}:%L - %m%n# 往文件输出
log4j.appender.fileAppender=org.apache.log4j.FileAppender
# 立即刷新
log4j.appender.fileAppender.ImmediateFlush = true
# 消息追加到文件中,不被覆盖
log4j.appender.fileAppender.Append=true
# 消息输出到指定文件中
log4j.appender.fileAppender.File=D:/log4j-log/log4j-log.log
# 日志输出模式可以灵活指定
log4j.appender.fileAppender.layout=org.apache.log4j.PatternLayout
# 日志输出模式细节
log4j.appender.fileAppender.layout.ConversionPattern=%d %5p %c{1}:%L - %m%n打印结果:
------------------------------------------------------
输入一个整数
20.5
2021-07-17 14:49:28,605 main  INFO Demo1:35 - 类型转换失败,请录入一个整数

配置文件图解:
在这里插入图片描述
Log4J点击下载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/330788.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DB2书籍推荐!

链接&#xff1a; http://blog.csdn.net/db2cn/article/details/4336619第一本《循序渐进DB2——DBA系统管理、运维与应用案例》&#xff1a;内容简介DB2数据库是IBM 公司关系型数据库核心产品&#xff0c;在国内以及全球有着广泛的应用。针对DB2初学者&#xff0c;本书循序渐进…

@Controller,@Service,@Repository,@Component详解

转载自 Controller,Service,Repository,Component详解 Controller 用来表示一个web控制层bean&#xff0c;如SpringMvc中的控制器。 Service 用来表示一个业务层bean。 Repository 用来表示一个持久层bean&#xff0c;即数据访问层DAO组件。 Component 用来表示一个平常的普通组…

thinking-in-java(12)通过异常处理错误

【12.0】开场白1&#xff09;java的基本理念&#xff1a;结构不佳的代码不能运行&#xff1b;2&#xff09;改进的错误恢复机制&#xff1a;是提供代码健壮性的最强有力的方式&#xff1b;3&#xff09;java异常&#xff1a;3.1&#xff09;java采用异常来提供一致的错误报告模…

分布式系统架构常识:CAP理论

转载自 分布式系统架构常识&#xff1a;CAP理论什么是CAP理论&#xff1f; 2000年7月&#xff0c;加州大学伯克利分校的Eric Brewer教授在ACM PODC会议上提出CAP猜想。2年后麻省理工学院的Seth Gilbert和NancyLynch从理论上证明了CAP&#xff0c;之后CAP理论正式成为分布式计算…

GIt代码管理仓库

1.Git的概念 a.Git是一个代码版本控制工具&#xff0c;有下面几个特点 <1>Git可以用于备份项目代码 <2>Git可以管理代码的各个版本 <3>Git可以方便大家协同工作 <4>Git可以方便代码追责 b.Git和SVN对比 SVN是集中式的版本控制系统&#xff0c;而Git是…

程序员三年的门槛该如何跨过去?

转自&#xff1a; http://blog.csdn.net/singit/article/details/78668490第一阶段&#xff1a;三年 我认为三年对于程序员来说是第一个门槛&#xff0c;这个阶段将会淘汰掉一批不适合写代码的人。这一阶段&#xff0c;我们走出校园&#xff0c;迈入社会&#xff0c;成为一名程…

静态资源Html基础语法

1.div划分【样式控制】 <style>div {/*显示边框*/border: 1px solid pink;/*宽度 占用屏幕的60%*/width: 60%;/*高度 500像素*/height: 500px;/*边框外边距*/margin: auto;/*文字居中*/text-align: center;/*height: 500px;*//*line-height: 500px;*/}</style>2.d…

关系型数据的分布式处理系统:Cobar

转载自 关系型数据的分布式处理系统&#xff1a;CobarCobar简介 Cobar是关系型数据的分布式处理系统&#xff0c;它可以在分布式的环境下像传统数据库一样为您提供海量数据服务。Github&#xff1a;https://github.com/alibaba/cobar整体架构图&#xff1a;快速启动场景 系统对…

thinking-in-java(16) 数组

【16.1】数组有什么特殊 1&#xff09;数组与其他类型容器的区别&#xff1a; 效率&#xff0c;类型和保持基本类型的能力&#xff1b;数组是效率最高的存储和随机访问对象引用序列的方式&#xff1b;数组大小固定&#xff0c;容器大小可以不固定&#xff0c;所以这增加了弹性…

推荐一个在线创作流程图、思维导图软件—ProcessOn

转载自 推荐一个在线创作流程图、思维导图软件—ProcessOn 最近要画流程图&#xff0c;破解了半天Visio2016没搞定&#xff0c;2016的估计都被封了&#xff0c;Visio收费又过贵&#xff0c;又不想折腾低版本的破解&#xff0c;所以找了个在线画图平台ProcessOn&#xff0c;没想…

静态资源Css基础语法

1.css的引入方式 <1>内联样式 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>引入方式1</title> </head> <body><!--内联样式--><h1 style"color: red; fon…

DevExperience(1712)

【1】在 DML 或 DDL 语句中&#xff0c;不要添加 数据库表前缀&#xff1a; 因为开发环境的数据库表名 和 生产环境的数据库表名 有可能不一样&#xff1b; 这个时候就有可能报 SQL 异常&#xff1b;造成生产事故&#xff1b;不推荐&#xff1a; select * from db_name.tbl_nam…

常用缓存淘汰算法(LFU、LRU、ARC、FIFO、MRU)

转载自 常用缓存淘汰算法&#xff08;LFU、LRU、ARC、FIFO、MRU&#xff09;缓存算法是指令的一个明细表&#xff0c;用于决定缓存系统中哪些数据应该被删去。 常见类型包括LFU、LRU、ARC、FIFO、MRU。最不经常使用算法&#xff08;LFU&#xff09;&#xff1a; 这个缓存算法使…

动态资源Servlet接口

1.Servlet接口的作用 Servlet是运行在Web服务器上的应用程序。Servlet本身是一个Java接口&#xff0c;它定义了浏览器访问服务器程序的规则&#xff0c;我们写服务器程序只需要按照需求复写Servlet方法即可 2.Servlet的体系结构 <1>直接继承实现类结构 <2>其他…

thinking-in-java(14)类型信息

【0】开场白 1&#xff09;运行时类型信息使得你可以在程序运行时发现和使用类型信息&#xff1b;2&#xff09;java是如何在运行时识别对象和类信息的&#xff1f;两种方式&#xff1a; 方式1&#xff09;传统的RTTI&#xff08;RunTime Type Identification 运行时类型定义&a…

服务降级的概念及应用手段

转载自 服务降级的概念及应用手段什么是服务降级 服务降级&#xff0c;就是对不怎么重要的服务进行低优先级的处理。说白了&#xff0c;就是尽可能的把系统资源让给优先级高的服务。资源有限&#xff0c;而请求是无限的。如果在并发高峰期&#xff0c;不做服务降级处理&#xf…

Servlet其他关联类---ServletConfig类

1.ServletConfig介绍 a.ServletConfig是Servlet的配置参数对象&#xff0c;在Servlet的规范中&#xff0c;允许为每一个Servlet都提供一些初始化的配置。所以&#xff0c;每个Servlet都有一个自己的ServletConfig b.作用:在Servlet的初始化时&#xff0c;把一些配置信息传递给…

thinking-in-java(19)枚举类型

【0】开场白 1&#xff09;关键字 enum 可以将一组具名的值的有限集合创建为一种新的类型&#xff0c;而这些具名的值可以作为常规的程序组件使用&#xff1b;2&#xff09;所有的枚举类都继承自 Enum&#xff0c;通过 enumClass.getSuperclass() class java.lang.Enum 得知。…

8条关于Web前端性能的优化建议

转载自 8条关于Web前端性能的优化建议 一般网站优化都是优化后台&#xff0c;如接口的响应时间、SQL优化、后台代码性能优化、服务器优化等。高并发情况下&#xff0c;对前端web优化也是非常重要的。 下面说说几种常见的优化措施。 1、HTML CSS JS位置 一般需要将CSS放页面最上…