- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当记录到 MemoryHandler 时,当 numofentries > size 时,MemoryHandler 会删除旧条目。
我想避免这种行为,或者至少在日志中标记旧条目被抑制。
小测试用例:
import java.util.logging.*;
public class SSCE01 {
public static void main (String [] args) {
Logger rootLogger = Logger.getLogger("");
rootLogger.removeHandler(rootLogger.getHandlers()[0]); //remove default Console Handler
ConsoleHandler ch = new ConsoleHandler();
Logger l = Logger.getLogger("test");
MemoryHandler mh = new MemoryHandler(ch,3,Level.OFF);
l.addHandler(mh);
l.severe("this shouldnt be logged");
l.severe("this shouldnt be logged");
l.severe("this shouldnt be logged");
l.severe("this should be logged");
l.severe("this should be logged");
l.severe("this should be logged");
mh.push();
}
}
最佳答案
这是一个坏主意,你会用痕迹填满内存机器。尽管如此,MemoryHandle 是一个循环缓冲区,因此当它被填满时,其他条目将被删除。如果您希望不删除条目,只需使用 Integer.MAX_VALUE 作为大小来构造它 - 这又是一个坏主意。这会影响你的应用程序性能,人们往往会避免这种情况。
考虑使用将跟踪转储到辅助存储中的处理程序,添加时间戳;并使用那里的跟踪构建您需要的任何逻辑。
编辑
根据您报告的代码,您可以将日志记录功能封装在另一个类中,该类记录 MemoryHandler
中的条目数。类似于:
class MyMemoryConsoleHandler {
private Logger rootLogger;
private MemoryHandler mh;
private Logger l;
private int size = 3;
private int entries = 0;
public MyMemoryConsoleHandler() {
this.rootLogger = Logger.getLogger("");
this.rootLogger.removeHandler(rootLogger.getHandlers()[0]);
ConsoleHandler ch = new ConsoleHandler();
this.l = Logger.getLogger("test");
this.mh = new MemoryHandler(ch,this.size,Level.OFF);
}
public synchronized void push() {
this.mh.push();
if (this.entries > this.size) {
this.l.severe("Entries in log discarded !!!");
this.mh.push();
}
this.entries = 0;
}
public synchronized void addMessage(String m) {
this.entries++;
this.l.severe(m);
}
}
不要使用 Java API 的日志记录调用,而是直接使用 MyMemoryConsoleHandler
,以便您可以控制推送到控制台的内容。
注意同步
方法,如果您有多线程应用程序,则需要这样做。否则你可能会遇到竞争条件。
关于java - 避免丢弃 MemoryHandler 中的旧条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6094855/
我正在尝试将 python MemoryHandler 添加到日志记录配置文件中。我正在使用与之前工作的文件处理程序类似的结构。我对收到的错误有点困惑,并且无法弄清楚我缺少什么才能将日志记录保存到内存
Python 的 logging模块有一个缓冲处理程序,MemoryHandler . 它需要一个capacity 参数。 容量的单位是什么? 最佳答案 缓冲区的容量是它可以容纳的条目数。每个条目代表
当记录到 MemoryHandler 时,当 numofentries > size 时,MemoryHandler 会删除旧条目。 我想避免这种行为,或者至少在日志中标记旧条目被抑制。 小测试用例:
我想在特定阈值后记录我的应用程序的消息。 10 条消息后说。我阅读了内存处理程序并使用了它。但是我发现它会立即记录消息,而不是像文档中所说的那样缓冲它们。这是代码 Handler h = new Fi
我找不到足够的文档来让它工作。我有非长时间运行的进程,这些进程在 stderr 上显示进度信息并使用 stdout 进行输出。我想要的是日志消息在进程退出时全部显示在最后,而且它也应该记录到一个文件中
我设置了日志记录模块 MemoryHandler 来排队 SMTPHandler 目标的调试和错误消息。我想要的是当包含所有调试语句的过程错误时发送一封电子邮件(每行一个)。相反,我得到的是每条调试消
我是一名优秀的程序员,十分优秀!