zoukankan      html  css  js  c++  java
  • C# 使用Trace记录程序日志

    在程序开发中,我们通常需要记录程序运行的状态,在程序部署后,发生的异常可以记录在日志中,便于发现程序潜在的问题。在.NET平台,有很多优秀的日志类库,例如Log4Net。如果程序很小,我们可以自己通过C#的Trace类来实现一个基本的日志记录功能。下面直接看代码:

    复制代码
        public class TraceHelper
        {
            private static TraceHelper _traceHelper;
    
            private TraceHelper()
            {
            }
    
            public static TraceHelper GetInstance()
            {
                if (_traceHelper == null)
                    _traceHelper = new TraceHelper();
    
                return _traceHelper;
            }
    
            public void Error(string message, string module)
            {
                Log(message, MessageType.Error, module);
            }
    
            public void Error(Exception ex, string module)
            {
                Log(ex.StackTrace, MessageType.Error, module);
            }
    
            public void Warning(string message, string module)
            {
                Log(message, MessageType.Warning, module);
            }
    
            public void Info(string message, string module)
            {
                Log(message, MessageType.Information, module);
            }
    
            private void Log(string message, MessageType type, string module)
            {
                Trace.WriteLine(
                    string.Format("{0},{1},{2},{3}",
                    DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                    type.ToString(),
                    module,
                    message));
            }
        }
    
        public enum MessageType
        {
           Information = 0,
           Warning = 1,
           Error = 2
        }
    }
    复制代码

    在App.config文件中添加(也可以在代码中创建TraceListener):

    复制代码
    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <startup> 
            <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
        </startup>
      <system.diagnostics>
        <trace autoflush="true" indentsize="0">
          <listeners>
            <add name="LogListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="LogConsoleApp.log"/>
          </listeners>
        </trace>
      </system.diagnostics>
    </configuration>
    复制代码

    使用也很简单,

            static void Main(string[] args)
            {
                TraceHelper.GetInstance().Info("This is a information message", "Main Function");
    
                TraceHelper.GetInstance().Error("This is an error message", "Main Function");
            }

    代码点击这里下载。

    感谢您的阅读。

  • 相关阅读:
    Minikube体验
    基于Vue、Bootstrap的Tab形式的进度展示
    Python 网络请求模块 urllib 、requests
    SRE学习笔记:分布式共识系统、Paxos协议
    ReactNative: 使用对话框组件AlertIOS组件
    ReactNative: 使用AsyncStorage异步存储类
    ReactNative: 使用网页组件WebView组件
    ReactNative: 使用标签栏组件TabBarIOS组件
    ReactNative: 使用像素密度类PixelRatio进行适配
    ReactNative: 使用尺寸类Dimensions获取屏幕尺寸
  • 原文地址:https://www.cnblogs.com/wangchaoyuana/p/7523624.html
Copyright © 2011-2022 走看看