SLF4J-什么是悬挂式或分离式标记? [英] SLF4J - What is a dangling or detached marker?

查看:15
本文介绍了SLF4J-什么是悬挂式或分离式标记?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在SLF4J中,我不完全确定detached marker是什么。该JavaDoc相当不明确。

几个问题:

  • 是否纯粹是标记的内存管理,即停止/启动被垃圾收集的标记?
  • 使用悬挂/分离的标记登录时会发生什么情况?
  • 如果标记已分离,您是否仍能对其进行筛选或将其关闭?
  • 为什么要在运行时分离标记?我可以理解创建自由形式的动态标记,从而节省内存(要点1),但稍后分离时,我发现这很奇怪。

推荐答案

我也有同样的问题,并尝试查找有关该问题的一些信息。

在1.3.1的SLF4J release notes中写着

为了响应Michael Newcomb提出的增强请求,现在可以从生成该标记的标记工厂的内部列表中分离该标记。

它链接到我再也找不到的Bugzilla错误#39。

邮件列表slf4j-user上的帖子Marker for object identification?与主题有关,但不包含逐字请求。

我的解释是:

  • 分离的标记未在内部列表中引用,可以进行垃圾回收。
  • AS标记可以具有子项:如果您创建了一个具有子项B和C的分离标记A,然后使用相同的名称重新检索标记A‘,则不能保证A==A’并且A‘可能不具有相同的子项,如果您不自己添加它们的话。
  • 我希望日志记录和筛选对正常标记和分离的标记具有相同的行为,但要注意子标记的情况。
  • 主要应用程序似乎是带有动态标识符的标记。在上面的邮件列表线程中,会话名称总是不同的。同一会话中的不同组件将其用作标记,您可以将其放入日志模式中,并在以后标识关联的日志消息。

顺便说一句,在slf4j的log4j实现log4j 2 documentation of Log4jMarkerFactory中,它说明了方法getDetachedMarker()

出于性能原因,Log4j不支持分离的标记。已附加返回的标记。

因此,分离标记可能只对某些记录库有用。

这篇关于SLF4J-什么是悬挂式或分离式标记?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆