java Logger 定义方式
天蓬老师
天蓬老师 2017-04-18 09:45:32
[Java讨论组]

定义Logger有两种方式, 如下:

第一种:

private static final Logger logger = LoggerFactory.getLogger(XX.class);

第二种:

protected final Logger logger = LoggerFactory.getLogger(getClass());

这两种方式哪种更好? 我个人更倾向于第二种. 求教高手.

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(7)
天蓬老师

都各有利弊,静态的省内存、cpu,实例化的可以结合IOC操作来注入,查了下资料,你可以看看
http://www.slf4j.org/faq.html...
http://wiki.apache.org/common...

黄舟

一般都是第一种吧,能private就尽量privatestatic final作为一个常量。

PHPz

看你的需要 如果有些别的类需要和设置了logger的类打印在同一个日志下 那么你甚至可以设置成public的 只要知道一个logger最终可以分解成一个日志文件 就可以知道怎么设置限制范围了

高洛峰

一般用第一种,用了第二种定义的话,如果你的类里面有静态方法,那在这个静态方法里面那就用不了这个logger对象了,至于访问修饰符,能private的话还是尽量private吧,除非你有特殊需求

天蓬老师

我一般写的第一种,所以也推荐啦。XX.class 应该比getClass()性能好。

高洛峰

使用lombok

@Slf4j
public class Test {

}

take it easy

PHP中文网

感谢 @netBuffer @FullStackDeveloper 的帮助和提供的官方资料,让我找到了答案:http://www.slf4j.org/faq.html...

Summary
In summary, declaring logger members as static variables requires less CPU time and have a slightly smaller memory footprint. On the other hand, declaring logger members as instance variables requires more CPU time and have a slightly higher memory overhead. However, instance variables make it possible to create a distinct logger environment for each application, even for loggers declared in shared libraries. Perhaps more important than previously mentioned considerations, instance variables are IOC-friendly whereas static variables are not.

我的解决方案如下:
1.declaring logger members as static variables
2.采用@FullStackDeveloper 分享的lombok,@Slf4j take it easy.

3ks!

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号