1.错误预览
![](https://img-blog.csdnimg.cn/img_convert/c8652fc3b530315752e958f6bac63313.png)
2.错误复现
// 主线程定义了一个对象
Label lb = new Label();
// 子线程调用该对象即会报此错误
lb.Content = "111";
原因是C#中不允许多个线程同时拥有操控一个对象的权利--类似主线程更新UI
3.解决方法
利用委托机制, 子线程向主线程发起一个委托, 由主线程触发相关动作帮助我们完成操作
// 委托
lb.Dispatcher.Invoke(new Action(
delegate
{
// ------- 需要完成什么操作,写在这里就可以了, 主线程会触发该Action来完成-------
lb.Content = "666";
})
);
4.代码实战部分
//hack 20230321
public static Action Login_Action;//声明事件
public Timer timer;//计时器声明
public WinVM()
{
事件触发绑定的方法
Login_Action += TimerLogin;
timer = new Timer(new TimerCallback(Execute), null, 2000, 10000);
}
// 创建回调触发方法
public static void Execute(object o)
{
Login_Action?.Invoke();
}
/// <summary>
/// 需要定时执行的方法
/// </summary>
public static void TimerLogin()
{
if (CommWithPCs.Instance.globalReLoginFlag)
{
long EmptyTime= GetLastInputTime();
if (EmptyTime>10*1000)
{
Window1 win = Window1.Instance;
//win.frm_MainPage.Navigate(null);
win.passwordBox.Dispatcher.Invoke(new Action(
delegate
{
win.passwordBox.Password = "";
})
);
win.Dispatcher.Invoke(new Action(
delegate
{
win.frm_MainPage.Navigate(null);
})
);
}
}
}