c#写日志(.text)

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Web;

namespace BMCMInterface
{
    public class LogFiles
    {
        private static string _fileName;
        private static Dictionary<long, long> lockDic = new Dictionary<long, long>();
        /// <summary> 
        /// 获取或设置文件名称 
        /// </summary> 
        public string FileName
        {
            get { return _fileName; }
            set { _fileName = value; }
        }

        ////<summary> 
        /// 构造函数 
        /// </summary> 
        /// <param name="byteCount">每次开辟位数大小,这个直接影响到记录文件的效率</param> 
        /// <param name="fileName">文件全路径名</param> 
        public LogFiles(string fileName)
        {
            _fileName = fileName;
        }

        /// <summary> 
        /// 构造函数 
        /// </summary>
        public LogFiles()
        { }

        /// <summary> 
        /// 创建文件 
        /// </summary> 
        /// <param name="fileName"></param> 
        public void Create()
        {
            if (System.IO.File.Exists(_fileName))
            {
                FileInfo logfileinfo = new FileInfo(_fileName);
                if (logfileinfo.Length > 10240000)
                {
                    GenerateNewLogFileName();
                }
            }
        }

        /// <summary> 
        /// 写入文本 
        /// </summary> 
        /// <param name="content">文本内容</param> 
        private void Write(string content, string newLine, string time)
        {
            if (string.IsNullOrEmpty(_fileName))
            {
                GenerateNewLogFileName();
            }

            Create();

            using (System.IO.FileStream fs = new System.IO.FileStream(_fileName, System.IO.FileMode.OpenOrCreate, System.IO.FileAccess.ReadWrite, System.IO.FileShare.ReadWrite, 8, System.IO.FileOptions.Asynchronous))
            {
                //Byte[] dataArray = System.Text.Encoding.ASCII.GetBytes(System.DateTime.Now.ToString() + content + "/r/n"); 
                Byte[] dataArray = System.Text.Encoding.Default.GetBytes(time + "  " + content + newLine);
                bool flag = true;
                long slen = dataArray.Length;
                long len = 0;
                while (flag)
                {
                    try
                    {
                        if (len >= fs.Length)
                        {
                            fs.Lock(len, slen);
                            lockDic[len] = slen;
                            flag = false;
                        }
                        else
                        {
                            len = fs.Length;
                        }
                    }
                    catch (Exception ex)
                    {
                        while (!lockDic.ContainsKey(len))
                        {
                            len += lockDic[len];
                        }
                    }
                }
                fs.Seek(len, System.IO.SeekOrigin.Begin);
                fs.Write(dataArray, 0, dataArray.Length);
                fs.Close();
            }
        }
        /// <summary> 
        /// 写入文件内容 
        /// </summary> 
        /// <param name="content"></param> 
        public void WriteLine(string content)
        {
            this.Write(content, System.Environment.NewLine, DateTime.Now.ToString());
        }
        /// <summary> 
        /// 写入文件 
        /// </summary> 
        /// <param name="content"></param> 
        public void Write(string content)
        {
            this.Write(content, "", "");
        }

        ///<summary>
        ///构造log文件名
        ///</summary>
        private void GenerateNewLogFileName()
        {
            //generate a new log file name
            string strDateTimeString = string.Format("{0:yyyyMMddHHmm}", System.DateTime.Now);
            string LogFile_Name = strDateTimeString + ".log";
            _fileName = AppDomain.CurrentDomain.BaseDirectory + LogFile_Name;
        }

    }

}
//赋值:LogFile.FileName =AppDomain.CurrentDomain.BaseDirectory + "logText.log";
 //调用:LogFile.WriteLine("获取异常:" + ex.Message + sql);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值