最近用户反映一些电脑启动程序就崩溃,还给演示了一个比较诡异的问题
“把软件重新拷贝到另外一个目录,就能正常运行"。还说过一段时间又不能运行需要在换个位置。
’由于当时没有设置全局异常,只能借助系统操作日志来分析, 系统日志记录不全,就说发生一个异常程序挂掉。
就简单加上全局异常捕获。
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:\Users\Administrator\AppData\Local\SuspendWpfApp,删除里面的文件即可。
Administrator:用户名, SuspendWpfApp:软件名。
为了彻底解决这个问题,不在使用 Properties.Settings.Default来保存信息,自己用文件来保存上次信息。
因为一旦userSettings出现问题,软件中依赖appSettings节点的信息将都获取不到。
配置文件初始化异常Configuration system failed to initializeshirley、 prezi、 美菜、 官方辟谣!防疫攻坚阶段DHL宣布对中国停运?假的!、 掌握这些小技巧,你就能顺利通过亚马逊账户审核!、 注意!这两大类产品都将被禁售!、 西班牙:巴塞罗那风情万种的性感沙滩、 冬天去哪里旅游 慢游武夷山、 何惧末日 最具正能量的出游地推荐、
没有评论:
发表评论