国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#實現程序單例日志輸出功能

2020-01-24 00:33:29
字體:
來源:轉載
供稿:網友

對于一個完整的程序系統,一個日志記錄是必不可少的。可以用它來記錄程序在運行過程中的運行狀態和報錯信息。比如,那些不想通過彈框提示的錯誤,程序執行過程中捕獲的異常等。

首先,在你的解決方案中,適當的目錄中新建一個類,比如 LogManager:

編寫如下代碼:

/// <summary>  /// 日志管理  /// </summary>  public class LogManager  {    private string _logDir; // 日志文件存放目錄    private static LogManager m_LogInstance; // 靜態單例對象    // 靜態構造函數    static LogManager()    {      m_LogInstance = new LogManager();    }    // 私有構造函數(必備函數,不允許外部對該類進行實例化)    private LogManager()    {      _logDir = Environment.CurrentDirectory + "http://Log";      this.DelOldFile();    }    /// <summary>    /// 屬性獲取單例對象    /// </summary>    public static LogManager LogInstance    {      get { return m_LogInstance; }    }    /// <summary>    /// 寫入一條日志記錄    /// </summary>    /// <param name="pLog">日志記錄內容</param>    public void WriteLog(string pLog)    {      lock (this._logDir) //排它鎖:防止主程序中出現多線程同時訪問同一個文件出錯      {        // 根據時間創建一個日志文件        var vDT = DateTime.Now;        string vLogFile = string.Format("{0}//Log{1}{2}{3}.log",_logDir,vDT.Year,vDT.Month,vDT.Day);        // 創建文件流,用于寫入        using (FileStream fs = new FileStream(vLogFile, FileMode.Append))        {          StreamWriter sw = new StreamWriter(fs);          sw.WriteLine("{0} >> {1}", vDT.ToString("yyyy-MM-dd HH:mm:ss"), pLog);          sw.Flush();          sw.Close();          fs.Close();        }      }    }    // 刪除過期文件    private void DelOldFile()    {      // 遍歷指定文件夾下所有子文件,將一定期限前的日志文件刪除。      if (!Directory.Exists(this._logDir))      {        // 如果文件夾目錄不存在        Directory.CreateDirectory(this._logDir);        return;      }      var vFiles = (new DirectoryInfo(this._logDir)).GetFiles();      for (int i = vFiles.Length - 1; i >= 0; i--)      {         // 指定條件,然后刪除        if (vFiles[i].Name.Contains("Log"))        {          if ((DateTime.Now - vFiles[i].LastWriteTime).Days > 7)          {            vFiles[i].Delete();          }        }            }    }  } // end class

其中,第8行-第26行是關于實現單例模式的一種方法。這樣,在你程序的需要位置執行:

LogManager.LogInstance.WriteLog("產生了一條日志記錄");

就會在指定文件中參數一條日志記錄了。

即:2016-11-23 23:53:45  >>  產生了一條日志記錄

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿拉尔市| 四子王旗| 南陵县| 弋阳县| 长武县| 玉门市| 洮南市| 江津市| 霸州市| 五寨县| 台湾省| 当阳市| 灵台县| 陇南市| 行唐县| 临沧市| 秦安县| 永修县| 塔城市| 桦甸市| 秦皇岛市| 阜新市| 儋州市| 舒兰市| 自治县| 慈利县| 斗六市| 光泽县| 无为县| 兰州市| 嘉黎县| 灵武市| 老河口市| 大足县| 托克托县| 马山县| 板桥市| 怀化市| 泰和县| 泗阳县| 大厂|