java实现简单的日志打印

本文介绍了如何使用java.lang.Throwable类来获取并打印当前调用栈的详细信息,包括文件名、类名、方法名和行号,从而实现简单的日志记录功能。

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

实现原理:
java.lang.Throwable类可以实时获取当前调用栈每一层调用的详细信息,包括文件名、类名、方法名和行号。
示例代码:

public class LocalLog {

    public static void log(String log){
        StackTraceElement[] stacks = new Throwable().getStackTrace();
        StackTraceElement stack1 = stacks[1];
        System.out.println("LOG POINT@"
                + "filename:"+stack1.getFileName()
                + ",classname:"+stack1.getClassName()
                + "methodname:"+stack1.getMethodName()
                + "lineno:"+stack1.getLineNumber());
        System.out.println("LOG INFO:"+log);
    }

    public static void main(String[] args){
        LocalLog.log("this is a test!");
    }
}

main方法执行结果:

LOG POINT@filename:LocalLog.java,classname:figo.fileParse.LocalLogmethodname:mainlineno:19
LOG INFO:this is a test!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值