Java里Logger类的基本用法是什么_Java日志基础API说明
发布时间 - 2026-01-05 00:00:00 点击率:次Java中Logger必须通过Logger.getLogger()获取实例,不可new;日志输出需检查Handler配置与级别设置;推荐用isLoggable()或占位符避免无效拼接;格式化由Handler的Formatter控制。
Java里用Logger前必须先获取实例
Java标准库的java.util.logging.Logger不是直接new出来的,必须通过Logger.getLogger(String name)获取。名字通常用类全限定名(如"com.example.MyService"),这样日志能按模块归类。重复调用同一名字会返回同一个实例,所以一般在类静态字段里初始化:
private static final Logger logger = Logger.getLogger(MyService.class.getName());
别写成new Logger()——它没有公开构造方法,编译就报错。
logger.info()等方法不打印任何内容?检查根处理器
默认情况下,Logger实例本身不输出日志,它把日志交给handler处理。JUL(Java Util Logging)默认只给根Logger配了ConsoleHandler,但子Logger默认useParentHandlers == true,所以多数情况能打到控制台。但如果发现logger.info("test")没输出,常见原因有:
- 该
Logger被显式设置了setUseParentHandlers(false),又没加自己的Handler - 根
Logger的Level设成了WARNING或更高,而info()是INFO级 - 应用服务器(如Tomcat)重置了JUL配置,屏蔽了控制台输出
快速验证:加一行logger.getParent().getLevel()看看根级别是不是INFO或更低。
日志级别和isLoggable()不是摆设
Logger支持SEVERE、WARNING、INFO、CONFIG、FINE、FINER、FINEST七级,默认启用到INFO。但注意:logger.info("user=" + user)这种写法,不管当前级别是否允许输出,都会先执行字符串拼接——可能浪费CPU或触发副作用(比如user.toString()抛异常)。
正确做法是用isLoggable(Level.INFO)提前判断,或改用带占位符的log(Level.INFO, "user={0}", user)(JUL原生支持{0}语法,仅当真正记录时才解析参数):
if (logger.isLoggable(Level.FINE)) {
logger.fine("Processing item: " + expensiveToString(item));
}
// 或更简洁:
logger.log(Level.FINE, "Processing item: {0}", item);
别依赖Logger的默认格式,自定义Formatter才可靠
JUL默认用SimpleFormatter,输出类似Jun 12, 2025 3:45:22 PM com.example.MyService doWork INFO: done。时间格式、类名、线程名都固定,很难适配监控系统或ELK。要改输出格式,得替换Handler的Formatter:
ConsoleHandler handler = new ConsoleHandler(); handler.setFormatter(new MyCustomFormatter()); // 继承 Formatter 重写 format() logger.addHandler(handler);
但注意:每个Handler独立持有Formatter,如果同时用了FileHandler和ConsoleHandler,得分别设置。另外,Logger本身不保存格式信息,所有格式化逻辑都在Handler侧。
实际项目中,JUL很少单独用到底层定制;更多是作为SLF4J桥接目标,或者被Log4j2/Logback替代。真要用JUL,重点盯住Handler生命周期和Level继承链——这两处出问题,日志就静默消失。
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
动图在线制作网站有哪些,滑动动图图集怎么做?
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
iOS中将个别页面强制横屏其他页面竖屏
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置
简历没回改:利用AI润色让你的文字更专业
如何用PHP工具快速搭建高效网站?
详解vue.js组件化开发实践
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
教你用AI将一段旋律扩展成一首完整的曲子
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
如何确认建站备案号应放置的具体位置?
再谈Python中的字符串与字符编码(推荐)
Laravel怎么实现验证码(Captcha)功能
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
如何在Windows服务器上快速搭建网站?
网站页面设计需要考虑到这些问题
JS碰撞运动实现方法详解
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
如何正确下载安装西数主机建站助手?
Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全
如何在腾讯云服务器上快速搭建个人网站?
Laravel DB事务怎么使用_Laravel数据库事务回滚操作
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
使用Dockerfile构建java web环境
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
原生JS获取元素集合的子元素宽度实例
Laravel如何实现事件和监听器?(Event & Listener实战)
北京企业网站设计制作公司,北京铁路集团官方网站?
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
QQ浏览器网页版登录入口 个人中心在线进入
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
微信小程序 scroll-view组件实现列表页实例代码
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
微信小程序 HTTPS报错整理常见问题及解决方案
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
网站建设要注意的标准 促进网站用户好感度!
移动端脚本框架Hammer.js
长沙做网站要多少钱,长沙国安网络怎么样?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
如何在云主机上快速搭建多站点网站?
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
,怎么在广州志愿者网站注册?

