zoukankan      html  css  js  c++  java
  • 日志记录.02_线程处理

    为了在业务系统中方便记录日志,可以建立一个线程类,专用于记录日志

        Type 

               TCustomLogThread = class(TThread)

    为了保证线程记录日志的有效性和安全性,在线程中可以添加一个临界区来进行保护,当高频记录日志时,可有效的保护日志记录安全

        Var

              FCS:TRTLCriticalSection;     --WinApi.Windows.pas

       --创建                  --释放

       InitializeCriticalSection(FCS);              DeleteCriticalSection(FCS);

        --进入保护                                             --日志处理完成后,要退出保护,否则其它线程永远无法记录日志了

              EnterCriticalSection(FCS);               LeaveCriticalSection(FCS);

       ------------------------------------------------------------------------

       另外,D同时还提供了一个类对上面进行了封装

       var

           FCS:TCriticalSection;   -- System.SyncObjs.pas                --建议使用这种类型

       --创建                                                --释放

           FCS := TCriticalSection.Create;        FCS.Destroy;

       --进入                                                --离开

          FCS.Enter; (FCS.Acquire)                  FCS.Leave; (FCS.Release)

    ----------------------------------------------------------------------------------------------

        保护操作:   a.进入保护;   b.日志记录          c.退出保护

    如果需要对日志进行日志级别,或者日志类型进行分类处理,可通过如下二种方法进行处理 

    A: 在日志线程中,开出需要进行分类标识的属性,供在执行日志时,通过分类标识处理日志文件或者处理日志内容节点内容

    B:另外一种方法就是再新建一个新的对象类,在自定义类中提供相关的日志线程对象,用来分别记录不同分类的日志

       如果是方案B的话,则在自定义类中需要配置临界面,以保证不同日志线程对同一日志资源访问的安全性

       如果是方案A的话,可以在日志线程中添加临界区,以保证外界调用日志记录函数时的安全性

                            

       

  • 相关阅读:
    教你在Access数据库中如何使用SQL
    供电计费管理系统(直管户版)南昌市科技进步奖[有软件截图]
    博主制作的DevExpress For D7 的自动汉化安装包[软件截图]
    SVN的Local方式:个人源码管理的好办法
    教务管理系统标准的具有中国特色的软件系统[有软件截图]
    博主制作的DevExpress For D7 的自动汉化安装包[软件截图]
    供电计费管理系统(台区版)与直管户版同为南昌市科技进步奖[有软件截图]
    教务管理系统标准的具有中国特色的软件系统[有软件截图]
    敏捷软件开发
    hdu 1263 STL的嵌套使用
  • 原文地址:https://www.cnblogs.com/jieling/p/5861641.html
Copyright © 2011-2022 走看看