如何实现IEnumerable<T>和IEnumerator接口,一个ASP.NET MVC日志模型的实现

namespace MyMvcApp.Models
{
    public class LogsModel:IEnumerable<IDictionary<string,string>>,IEnumerator<IDictionary<string,string>>
    {
        private TextReader reader;

        private IDictionary<string, string> currentLog;

        private string logFileName { get; set; }

        public int LogCount { get; set; }


      
        public LogsModel(string logFileName = @"logs\sys.log")
        {
            currentLog = new Dictionary<string, string>();
            this.logFileName = AppDomain.CurrentDomain.BaseDirectory + logFileName;
            InitLogReader(this.logFileName);

        }

        public void CloseLogFile()
        {
            if (reader != null)
            {
                reader.Close();
                reader = null;
            }
        }

        public long LogByteSize
        {
            get
            {
                FileInfo fi = new FileInfo(logFileName);
                return fi.Length;
            }
        }

        public void ClearLog()
        {
            CloseLogFile();
            TextWriter writer = new StreamWriter(logFileName,false);
            writer.Write("");
            writer.Close();
        }

        private void InitLogReader(string logFileName)
        {
            try
            {
                reader = new StreamReader(logFileName);
            }
            catch (FileNotFoundException e)
            {
                File.CreateText(logFileName);
                throw (e);
            }
            finally
            {
                reader = new StreamReader(logFileName);
            }
        }

        public IDictionary<string, string> Current
        {
            get
            {
                string line = reader.ReadLine();
                try
                {
                    if (!string.IsNullOrEmpty(line))
                    {
                        foreach (string pair in line.Split(';'))
                        {
                            string[] keyValue = pair.Split(':');
                            string key = keyValue[0];
                            string value = keyValue[1];
                            if (keyValue.Length > 2)
                            {
                                value += ":" + keyValue[2];
                            }
                            currentLog.Add(key, value);
                        }
                    }
                    return currentLog;
                }
                catch (Exception e)
                {
                    throw e;
                }
            }
        }

        object IEnumerator.Current
        {
            get
            {
                return Current;
            }
        }

        public void Reset()
        {
            CloseLogFile();
            LogCount = 0;
            InitLogReader(logFileName);
        }

        public bool MoveNext()
        {
            currentLog.Clear();
            if (reader.Peek() > -1)
            {
                LogCount++;            
                return true;
            }
            CloseLogFile();
            return false;
        }

        void IEnumerator.Reset()
        {
            Reset();
        }

        bool IEnumerator.MoveNext()
        {
            return MoveNext();
        }

        public void Dispose()
        {
            CloseLogFile();
        }

        public IEnumerator<IDictionary<string,string>> GetEnumerator()
        {
            return this;
        }

        IEnumerator IEnumerable.GetEnumerator()
        {
            return (IEnumerator)this;
        }
       
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值