代码:
using log4net; SunCreate.CombatPlatform.Security; System; System.Collections.Generic; System.Linq; System.Text; System.Windows.Threading; namespace SunCreate.CombatPlatform.Client { /// @H_404_33@<summary> @H_404_33@/// 线程帮助类(处理单线程任务) @H_404_33@</summary> public class ThreadHelper { private static ILog _log = log4net.LogManager.GetLogger(typeof(ThreadHelper)); @H_404_33@<summary> @H_404_33@ 执行 @H_404_33@ 例:ThreadHelper.Run(() => { },(ex) => { }); @H_404_33@</summary> @H_404_33@<param name="doWork">在线程中执行@H_404_33@</param> @H_404_33@<param name="errorAction">错误处理@H_404_33@</param> static System.Threading.Tasks.Task Run(Action doWork,Action<Exception> errorAction = null) { System.Threading.Tasks.Task task = System.Threading.Tasks.Task.Factory.StartNew(() => { try { if (doWork != ) doWork(); } catch (Exception ex) { _log.Error(@H_404_33@"@H_404[email protected] 错误@H_404_33@",ex); if (!SP.Get<IOnlineservice>().GetNetStatus()) { SP.Get<iuiManager>().dispatcher.BeginInvoke(new Action(() => { TaskDialog.Show(@H_404_33@连接数据库失败,请联系系统管理员,给您带来不便,敬请谅解@H_404_33@); })); } else { SP.Get<iuiManager>().dispatcher.BeginInvoke( { new WaitingWindow(@H_404_33@查询失败,请联系系统管理员,给您带来不便,敬请谅解@H_404_33@).Show(); })); } if (errorAction != ) errorAction(ex); } }); return task; } @H_404_33@ 封装dispatcher.BeginInvoke @H_404_33@ 例:ThreadHelper.BeginInvoke(this.dispatcher,() => { },1)">static void BeginInvoke(dispatcher dispatcher,Action action,1)">) { dispatcher.BeginInvoke( { action(); } ThreadHelper.BeginInvoke 错误404_33@加载失败,请联系系统管理员,给您带来不便,敬请谅解@H_404_33@); ) errorAction(ex); } })); } } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。