WPF 日志文件

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;
using System.Threading;


namespace mySerialPort.Com
{
    class Log
    {
        private static string debug_grade = "DEBUG";
        public static StackFrame stackFrame = new StackFrame();
        private static TextWriterTraceListener listner = null;
        // 输出跟踪文件
        private static string TRACE_FILE = null;
        private static Mutex mute = new Mutex(true);
        /// <summary>
        /// 初始化路径
        /// </summary>
        /// <param name="path"></param>
        public static void InitFilePath(string path)
        {
            mute.WaitOne();
            TRACE_FILE = null;
            TRACE_FILE = string.Copy(path);
            mute.ReleaseMutex();
        }
        /// <summary>
        /// 打印消息
        /// </summary>
        /// <param name="traceName"></param>
        /// <param name="traceMessage"></param>
        public static void Trace(string traceName, string traceMessage)
        {
            // 变量定义
            DateTime time = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
            string file = System.Environment.CurrentDirectory + "\\" + time.ToString("yyyy_MM_dd") + ".log";


            StringBuilder message = null;


            if (listner == null)
            {
                TRACE_FILE = file;
                try
                {
                    listner = new TextWriterTraceListener(TRACE_FILE);
                    System.Diagnostics.Trace.Listeners.Add(listner);
                    System.Diagnostics.Trace.IndentLevel = 0;
                    System.Diagnostics.Trace.AutoFlush = true;
                }
                catch (System.Exception)
                {
                    return;
                }
            }
            else
            {
                if (TRACE_FILE != file)
                {
                    TRACE_FILE = file;
                    listner.Close();
                    listner.Dispose();


                    listner = new TextWriterTraceListener(TRACE_FILE);
                    System.Diagnostics.Trace.Listeners.Add(listner);
                    System.Diagnostics.Trace.IndentLevel = 0;
                    System.Diagnostics.Trace.AutoFlush = true;
                }
            }
            message = new StringBuilder();
            message.Append("[");
            message.Append(DateTime.Now);
            message.Append("] ");
            message.Append("[");
            message.Append(traceName);
            message.Append("] ");
            message.Append(traceMessage);
            switch (debug_grade)
            {
                case "DEBUG":
                    System.Diagnostics.Trace.WriteLine(message.ToString());
                    break;
                case "MESSAGE":
                    if (traceName.Equals("MESSAGE") ||
                        traceName.Equals("WARING") ||
                        traceName.Equals("ERROR"))
                        System.Diagnostics.Trace.WriteLine(message.ToString());
                    break;
                case "WARING":
                    if (traceName.Equals("WARING") ||
                       traceName.Equals("ERROR"))
                        System.Diagnostics.Trace.WriteLine(message.ToString());
                    break;
                case "ERROR":
                    if (traceName.Equals("ERROR"))
                        System.Diagnostics.Trace.WriteLine(message.ToString());
                    break;
            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值