123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Threading;
- using System.Threading.Tasks;
- using System.Windows;
- using System.Windows.Forms;
- using IntelligentControlForsx.ChildForms;
- using IntelligentControlForsx.Service;
- using IntelligentControlForsx.Service.AGC;
- using IntelligentControlForsx.Service.AGC.Domain;
- using IntelligentControlForsx.Service.WindturbineControl.IntPtrSvc;
- using IntelligentControlForsx.Service.ZM;
- using IntelligentControlForsx.Start;
- using IntelligentControlForsx.Test;
- using Gyee_Control.View;
- using System.Text;
- using log4net;
- using WisdomClient;
- using WisdomClient.data;
- using Application = System.Windows.Forms.Application;
- namespace IntelligentControlForsx
- {
- static class Program
- {
- private static ILog logger = LogManager.GetLogger("AppInfoLog");
- /// <summary>
- /// 应用程序的主入口点。
- /// </summary>
- [STAThread]
- static void Main()
- {
- try
- {
- //设置应用程序处理异常方式:ThreadException处理
- Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
- //处理UI线程异常
- Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
- //处理非UI线程异常
- AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);
- Application.EnableVisualStyles();
- Application.SetCompatibleTextRenderingDefault(false);
- GetGycpToCache();
- #region 控制命令发送线程
- Thread sendTaskThread = new Thread(TaskSendSvc.SendCmd);
- sendTaskThread.IsBackground = true;
- sendTaskThread.Start();
- #endregion
-
- Application.Run(new MainWindow());
- }
- catch (Exception ex)
- {
- logger.Error(ex);
- //throw;
- }
- }
- public static void GetGycpToCache()
- {
- ControlIntPtr svc = ControlIntPtr.GetControlIntPtr();
- svc.init();
- }
- static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
- {
- string str = GetExceptionMsg(e.Exception, e.ToString());
- logger.Error(str);
- //MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
- //LogManager.WriteLog(str);
- }
- static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
- {
- string str = GetExceptionMsg(e.ExceptionObject as Exception, e.ToString());
- logger.Error(str);
- //MessageBox.Show(str, "系统错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
- //LogManager.WriteLog(str);
- }
- /// <summary>
- /// 生成自定义异常消息
- /// </summary>
- /// <param name="ex">异常对象</param>
- /// <param name="backStr">备用异常消息:当ex为null时有效</param>
- /// <returns>异常字符串文本</returns>
- static string GetExceptionMsg(Exception ex, string backStr)
- {
- StringBuilder sb = new StringBuilder();
- sb.AppendLine("****************************异常文本****************************");
- sb.AppendLine("【出现时间】:" + DateTime.Now.ToString());
- if (ex != null)
- {
- sb.AppendLine("【异常类型】:" + ex.GetType().Name);
- sb.AppendLine("【异常信息】:" + ex.Message);
- sb.AppendLine("【堆栈调用】:" + ex.StackTrace);
- }
- else
- {
- sb.AppendLine("【未处理异常】:" + backStr);
- }
- sb.AppendLine("***************************************************************");
- return sb.ToString();
- }
- }
- }
|