zoukankan      html  css  js  c++  java
  • kbmMWLog同时输出日志到多个日志管理器

    kbmMWLog日志框架,针对不同的业务情况,提供了多种日志管理器:

    • TkbmMWStreamLogManager
    • TkbmMWLocalFileLogManager
    • TkbmMWSystemLogManager
    • TkbmMWStringsLogManager
    • TkbmMWProxyLogManager
    • TkbmMWTeeLogManager
    • TkbmMWNullLogManager

    这些日志管理器,针对不同的日志输出对象而实现,比如将日志输出到文件、TStrings,Stream、系统控制台等。

     那如果想同时输出日志到多种对象怎么办呢?例如:想用文件记录日志的同时,也想输出到系统控制台以及界面上的Memo控件,在调试时能直接看到日志内容。非常幸运,作者已经为我们考虑到并完美实现,那就是用上面日志管理器TkbmMWTeeLogManager。直接看代码:

    procedure TForm1.Button5Click(Sender: TObject);
    var
       filelogmgr:IkbmMWLocalFileLogManager;
       systemlogmgr:IkbmMWSystemLogManager;
       teelogmgr:IkbmMWTeeLogManager;
    stringslogmgr:TkbmMWStringsLogManager;
    begin // 准备三个日志管理器 (系统及本地文件及Strings) // 然后定义一个tee日志管理器,并将系统及本地文件日志管理器传给tee日志管理器 filelogmgr:=TkbmMWLocalFileLogManager.Create('.log.txt','.audit.txt'); filelogmgr.FileOptions:=[mwlfoDeleteOldLog,mwlfoDeleteOldAudit]; systemlogmgr:=TkbmMWSystemLogManager.Create;
    //用Memo显示日志 stringslogmgr:=TkbmMWStringsLogManager.Create(Memo1.Lines);
    //定义一个tee日志管理器,让日志信息传递给另外两个日志管理器 teelogmgr:=TkbmMWTeeLogManager.Create(filelogmgr,systemlogmgr,stringslogmgr); Log.LogManager:=teelogmgr;

    //忽略指定的异常,不记录到日志
    Log.LogManager.IgnoreException(EMyException);
    end;

    这是从作者提供的Demo中拿来并进一步完善的代码,先建立文件日志管理器filelogmrg,系统日志管理器systemlogmgr,然后再建一个teelogmgr,将filelogmrg,systemlogmgr作为tee日志管理器的Create方法的参数,同时传给teelogmgr对象,最后将teelogmgr设置为全局对象Log的管理器。我做了补充,让日志同时显示到Memo控件上,因为又加了StringsLogManager管理器。

    现在日志就同时输出到文件及系统及控件Memo这三个日志管理器对象中去了。可以分别对这三个日志管理器做进一步的设置,例如,在文件日志中记录所有类型的日志,而在Memo中只显示Debug,Error,Fatal类型的日志,用下面代码设置:

    stringslogmgr.LogTypeFilter:=[mwltDebug,{mwltInfo,mwltWarning,}mwltError,mwltFatal{,mwltAudit}];
  • 相关阅读:
    大家帮忙出几个招聘考试题目吧
    单元测试和设计模式在重构中的应用
    想起去年和女朋友第一次去吃饭的事情
    为什么我们常忘记使用正则表达式
    .NET实用设计模式:观察者模式(Observer)
    一个Outlook宏写的小程序,献给象我一样粗心大意的人
    单元测试应该测什么,不应该测什么?
    .NET实用设计模式:工厂模式(Factory)
    2021 系统架构设计师备考分享
    系统架构设计师论文企业集成
  • 原文地址:https://www.cnblogs.com/kinglandsoft/p/9216646.html
Copyright © 2011-2022 走看看