- A+
所属分类:.NET技术
最近用户反映一些电脑启动程序就崩溃,还给演示了一个比较诡异的问题
“把软件重新拷贝到另外一个目录,就能正常运行"。还说过一段时间又不能运行需要在换个位置。
’由于当时没有设置全局异常,只能借助系统操作日志来分析, 系统日志记录不全,就说发生一个异常程序挂掉。
就简单加上全局异常捕获。
public class ExceptionHelper { public static void InitException() { Application.Current.DispatcherUnhandledException += Application_DispatcherUnhandledException; AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException; } private static void Application_DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e) { LogManager.WriteException(e.Exception); e.Handled = true; } private static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e) { var exception = e.ExceptionObject as Exception; if (exception != null) { LogManager.WriteException(exception); } } }
加入日志详细信息后,看到提示 Configuration system failed to initialize错误信息。然后借助搜索,找到一篇文章。
了解到原因两种:
一、config 文件中 <configSections> 的位置顺序有关或者内容格式错误。
二、包含了User作用域的配置项的时候,user.config文件损坏了。
结合自己的程序确实用道<configSections>这个节点,用来保存程序在屏幕的位置,该节点已经在最上面,检测内容格式也是正常。
那就剩下第二种可能了,找位置:C:UsersAdministratorAppDataLocalSuspendWpfApp,删除里面的文件即可。
Administrator:用户名, SuspendWpfApp:软件名。
为了彻底解决这个问题,不在使用 Properties.Settings.Default来保存信息,自己用文件来保存上次信息。
因为一旦userSettings出现问题,软件中依赖appSettings节点的信息将都获取不到。