log4j
(在IDEA中)
第一部分:配置log4j 添加log4j-1.2.17.jar
第二部分: 添加log4j.properties配置文件
### 设置Logger输出级别和输出目的地 ###
log4j.rootLogger=debug, stdout,logfile
### 把日志信息输出到控制台 ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.err
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
### 把日志信息输出到文件:jbit.log ###
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=jbit.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %l %F %p %m%n
Log4j的使用
需求:使用log4j输出日志到控制台和文件
按照控制台提示输入被除数和除数
如果输入不为数字,记录error日志;如果除数为 0,记录warn日志
如果正常输入记录info日志
// 需要使用log4j日志来记录操作
Logger logger = Logger.getLogger(Log4jTest.class);
Scanner input = new Scanner(System.in);
try {
System.out.println("请输入被除数");
int num = input.nextInt();
logger.info("被除数:"+num);
System.out.println("请输入除数");
int num1 = input.nextInt();
logger.info("除数:"+num1);
logger.info("运算结果:num/num1="+num/num1);
} catch (InputMismatchException e) {
logger.error("输入的不是数字" + e.getMessage());
} catch (ArithmeticException e) {
logger.warn("除数不能为0" + e.getMessage());
}
单元测试
用main方法测试好不好?不好!
1.不能一起运行!
2.大多数情况下需要人为的观察输出确定是否正确
对于程序员来说,如果养成了对自己写的代码进行单元测试的习惯,不但可以写出高质量的代码,而且还能提高编程水平
@Test :定义一个测试方法的标志
@Test(timeout=1000) :设置超时时间,如果测试时间超过了你定义的timeout,测试失败
@Test(expected) : 申明出会发生的异常,比如 @Test(expected =Exception.class)
@Before : 跟junit 3.8 上的setUp() 方法同样的效果,方法名最好和setUp()一样,但不强求,在每一个测试方法之前被执行
@After : 跟junit 3.8 上的tearDown() 方法同样的效果,方法名最好和tearDown()一样,但不强求,在每一个测试方法之后被执行
@BeforeClass : 被该注解申明的方法,功能是:在所有的测试方法之前执行,只执行一次
@AfterClass : 被该注解申明的方法,功能是:在所有的测试方法之后执行,只执行一次
@Ignore :让 测试方法 或 测试类 不被执行,让其失去测试的功能
public class Main {
Logger logger = Logger.getLogger(Main.class);
public void add(){
int num = 2;
int num1 =3;
logger.info("运算结果:num+num1="+(num+num1));
}
}
测试类
Logger logger = Logger.getLogger(CalculatorTest.class);
Main main=new Main();
private long time;
@Test
public void add1(){
main.add();
}
@Before
public void befor(){
time=System.currentTimeMillis();
}
@After
public void after(){
time=System.currentTimeMillis()-time;
logger.info("执行时间"+time);
}
}
输出结果
INFO - 运算结果:num*num1=6
INFO - 执行时间5