今天看了一篇文章,說的是使用微軟自帶的日志類寫日志,然后晚上我就花了2個多小時自己動手試了一下,然后模仿者自己封裝了一個類庫。
下面是自己封轉的類:

/***** * 創建人:金河 * 創建日期:2014-4-2 22:43 * 內容:日志類 */ using System; using System.Collections.Generic; using System.Text; using System.Diagnostics; using System.IO; namespace Log { /// <summary> /// 繼承TraceListener /// (1)必須要重寫的方法void Write(string message);void WriteLine(string message); /// (2)子類方法重寫必須和父類方法返回值、參數列表完全相同 /// </summary> public class Log : TraceListener { private string m_fileName; // 文件名 private string m_filePath; // 文件路徑 public string FileFullPath { get { if (Directory.Exists(m_filePath) == false) { Directory.CreateDirectory(m_filePath); } return m_filePath.TrimEnd('/') + "/" + m_fileName; } } public Log() { m_fileName = DateTime.Now.ToString("yyyy-MM-dd") + ".txt"; // 默認文件名為 今天的日期 m_filePath = AppDomain.CurrentDomain.BaseDirectory + "/log"; // 默認路徑在當前域log文件夾下面 } public Log(string sFileName) { m_fileName = sFileName; m_filePath = AppDomain.CurrentDomain.BaseDirectory + "/log"; //默認路徑在當前域log文件夾下面 } public override void Write(string message) { WriteLine(message); } public override void WriteLine(string message) { WriteLine(null, message); } /// <summary> /// 將異常或信息寫入日志 /// </summary> /// <param name="exception"></param> /// <param name="message"></param> public override void WriteLine(object exception, string message) { string sMsg = Environment.NewLine + DateTime.Now.ToString() + Environment.NewLine; if (!string.IsNullOrEmpty(message)) //如果信息不為空,加在最前面 { sMsg += message; } if (exception is Exception) { Exception ex = (Exception)exception; sMsg += ex.Message + Environment.NewLine; // 錯誤提示 sMsg += ex.StackTrace; // 堆棧信息 } else if (exception != null) { sMsg += exception.ToString(); } File.AppendAllText(FileFullPath, sMsg); } } }
下面是文檔地址:
利用C#自帶組件強壯程序日志