日志如何打印异常堆栈信息。

package com.doctor.slf4j;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 如何打印异常堆栈信息。
 * @author doctor
 *
 * @time   2014年12月11日 上午9:49:00
 */
public class LogThrowableRule {
	private final Logger log = LoggerFactory.getLogger(getClass());
	
	/**
	 * 这种e.toString()方法只是得到异常信息,异常堆栈没有得到
	 */
	@Test
	public void test_wrongLogThrowable(){
		try {
			int test = 10/0;
		} catch (Exception e) {
			log.error("error" + e);
			//main  ERROR c.d.s.LogThrowableRule -
			//                         errorjava.lang.ArithmeticException: / by zero
		}
	}
	
	/**
	 * 得到异常堆栈信息正确的log方法
	 */
	@Test
	public void test_rightWayGetInfoForThrowable(){
		int a = 10;
		int b = 0;
		try {
			
			int test = a/b;
		} catch (Exception e) {
			log.error("error" ,e);
			//main  ERROR c.d.s.LogThrowableRule -
			//			error
			//java.lang.ArithmeticException: / by zero
			//          at com.doctor.slf4j.LogThrowableRule.test_rightWayGetInfoForThrowable(LogThrowableRule.java:35) ~[classes/:na]
			//          at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_11]
			//          .............
			
			String msg = String.format("{error:'%s/%s'}", a,b);//string带参数,利用String.format
			log.error(msg, e);
		}
	}
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dreamer who

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值