public class Global : System.Web.HttpApplication
    {
        private static event Action eventActions;
        /// <summary>
        ///  当前正在运行的异步线程池
        /// </summary>
        private static Dictionary<string, IAsyncResult> diyAsync = new Dictionary<string, IAsyncResult>();
        protected void Application_Start(object sender, EventArgs e)
        {
            eventActions += MyClass.Writer;//任务(可以处理多个方法)
            System.Timers.Timer aTimer = new System.Timers.Timer();
            aTimer.Elapsed += new System.Timers.ElapsedEventHandler(OnTimedEvent);
            aTimer.Interval = 200;
            aTimer.Enabled = true;
        }
        /// <summary>
        /// 定时执行任务
        /// </summary>
        /// <param name="source"></param>
        /// <param name="e"></param>
        private static void OnTimedEvent(object source, ElapsedEventArgs e)
        {
            foreach (Action action in eventActions.GetInvocationList())
            {
                try
                {
                    if (diyAsync.Any(p => p.Key == action.Method.Name) && !diyAsync[action.Method.Name].IsCompleted)
                        continue;
                    diyAsync[action.Method.Name] = action.BeginInvoke(null, null);
                }
                catch (Exception ex)
                {
                    //任务执行出错
                }
            }
        }
        protected void Session_Start(object sender, EventArgs e)
        {
            string name = System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
        }

        protected void Application_BeginRequest(object sender, EventArgs e)
        {
           string name=System.Reflection.MethodBase.GetCurrentMethod().Name;
           WH_WriteLog.WriteLog(name);
        }

        protected void Application_AuthenticateRequest(object sender, EventArgs e)
        {
            string name=System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
        }

        protected void Application_Error(object sender, EventArgs e)
        {
            string name = System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
            WH_WriteLog.WriteLog(e.ToString());
        }

        protected void Session_End(object sender, EventArgs e)
        {
            string name = System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
        }

        protected void Application_End(object sender, EventArgs e)
        {
            string name = System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
        }
    }

    public class MyClass
    {
        public static void Writer()
        {
            string name = System.Reflection.MethodBase.GetCurrentMethod().Name;
            WH_WriteLog.WriteLog(name);
        }
    }

 

posted on 2018-11-12 09:41  许一朵岁月  阅读(1162)  评论(0编辑  收藏  举报