日志记录工具log4j 以及 单元测试

本文介绍如何在IntelliJ IDEA中配置Log4j并使用log4j记录不同级别的日志信息。此外,还详细介绍了如何通过JUnit进行单元测试,包括测试方法的标记、执行前后准备与清理的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值