异步保存程序运行日志

/// <summary>
/// 异步保存
/// </summary>
/// <param name="state">日志实体</param>
private static void AsyncSave(object state)
{
    try
    {
        LogStruct logStruct = (LogStruct)state;
        Mutex fileMutex = new Mutex(false, logStruct.MutexName);
        try
        {
            // 请求互斥体的所有权,若成功则进入临界区,否则等待
            fileMutex.WaitOne();
            // 在临界区中操作临界资源,即写入数据
            FileInfo info = new FileInfo(logStruct.Path);
            DirectoryInfo dinfo = new DirectoryInfo(info.DirectoryName);
            if (!dinfo.Exists)
            {
                dinfo.Create();
            }
            StreamWriter writer = !info.Exists ? info.CreateText() : info.AppendText();
            // 添加处理时间
            string s = string.Format("[{0}]\r\n", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"));
            string e = "\r\n----\r\n";
            logStruct.Massage = s + logStruct.Massage + e;
            writer.WriteLine(logStruct.Massage);
            writer.Flush();
            writer.Close();
        }
        catch (ThreadInterruptedException)
        {
            Console.Write("线程被中断");
        }
        catch (Exception e)
        {
            Console.WriteLine(e.Message);
        }
        finally
        {
            // 释放互斥体的所有权
            fileMutex.ReleaseMutex();
        }
        Thread.Sleep(200);
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message);
    }

}

/// <summary>
/// 日志实体
/// </summary>
public struct LogStruct
{
    public string Massage;
    public string Path;
    public string MutexName;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值