分享一个记录日志的类,可多线程使用。

好久没写博客了,今天分享一个自己用的日志类,非原创,借鉴了前辈的一个想法,然后修改来的。

日志我们是必须的,现在程序都是多线程并发了,记日志就有可能出现问题了,lock?影响性能。log4net太重量级了,本日志是一个轻量级的小工具。

 废话不多说,看源码:

 

  1 using System;
  2 using System.Collections.Generic;
  3 using System.IO;
  4 using System.Text;
  5 
  6 namespace GEDU.CourseOnline.Common
  7 {
  8     /// <summary>
  9     /// 日志类(多线程版)
 10     /// </summary>
 11     public class LogHelper
 12     {
 13         private string _fileName;
 14         private static Dictionary<long, long> lockDic = new Dictionary<long, long>();
 15 
 16         /// <summary>  
 17         /// 获取或设置文件名称  
 18         /// </summary>  
 19         public string FileName
 20         {
 21             get { return _fileName; }
 22             set { _fileName = value; }
 23         }
 24 
 25         /// <summary>  
 26         /// 构造函数  
 27         /// </summary>
 28         /// <param name="fileName">文件全路径名</param>  
 29         public LogHelper(string fileName)
 30         {
 31             if (string.IsNullOrEmpty(fileName))
 32             {
 33                 throw new Exception("FileName不能为空!");
 34             }
 35             Create(fileName);
 36             _fileName = fileName;
 37         }
 38 
 39         /// <summary>  
 40         /// 创建文件路径
 41         /// </summary>  
 42         /// <param name="fileName">文件路径</param>  
 43         public void Create(string fileName)
 44         {
 45             var directoryPath = Path.GetDirectoryName(fileName);
 46             if (string.IsNullOrEmpty(directoryPath))
 47             {
 48                 throw new Exception("FileName路径错误!");
 49             }
 50             if (!Directory.Exists(directoryPath))
 51             {
 52                 Directory.CreateDirectory(directoryPath);
 53             }
 54         }
 55 
 56         /// <summary>  
 57         /// 写入文本  
 58         /// </summary>  
 59         /// <param name="content">文本内容</param>
 60         /// <param name="newLine">换行标记</param>  
 61         private void Write(string content, string newLine)
 62         {
 63             using (FileStream fs = new FileStream(_fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite, 8, FileOptions.Asynchronous))
 64             {
 65                 Byte[] dataArray = Encoding.UTF8.GetBytes(content + newLine);
 66                 bool flag = true;
 67                 long slen = dataArray.Length;
 68                 long len = 0;
 69                 while (flag)
 70                 {
 71                     try
 72                     {
 73                         if (len >= fs.Length)
 74                         {
 75                             fs.Lock(len, slen);
 76                             lockDic[len] = slen;
 77                             flag = false;
 78                         }
 79                         else
 80                         {
 81                             len = fs.Length;
 82                         }
 83                     }
 84                     catch (Exception ex)
 85                     {
 86                         while (!lockDic.ContainsKey(len))
 87                         {
 88                             len += lockDic[len];
 89                         }
 90                     }
 91                 }
 92                 fs.Seek(len, SeekOrigin.Begin);
 93                 fs.Write(dataArray, 0, dataArray.Length);
 94                 fs.Close();
 95             }
 96         }
 97 
 98         /// <summary>  
 99         /// 写入文件内容  
100         /// </summary>  
101         /// <param name="content">内容</param>  
102         public void WriteLine(string content)
103         {
104             this.Write(content, Environment.NewLine);
105         }
106 
107         /// <summary>  
108         /// 写入文件内容  不换行
109         /// </summary>  
110         /// <param name="content">内容</param>  
111         public void Write(string content)
112         {
113             this.Write(content, "");
114         }
115     }
116 }
View Code

 

用法:

1 string strPath = HttpContext.Current.Server.MapPath(string.Format("/Log/{0:yyyyMMdd}.txt", DateTime.Today));
2 //string strPath = string.Format(@"D:\Log\{0:yyyyMMdd}.txt", DateTime.Today);
3 LogHelper logHelper = new LogHelper(strPath);
4 logHelper.WriteLine(sWord + "  时间:" + DateTime.Now);

 

如有不足还请指教。

posted @ 2014-12-05 22:06  清朗的晨风  阅读(4027)  评论(9编辑  收藏  举报