在我们进行多线程开发的时候,会遇到给主线程的控件赋值,如果直接赋值的话软件跑起来会提示“线程间操作无效: 从不是创建控件“labelXXX”的线程访问它。”
解决方案:使用委托,具体使用下面哪种按实际情况决定
/// <summary>
/// 在主线程/其他线程更新控件
/// </summary>
/// <param name="code">操作识别码</param>
/// <param name="arg">辅助参数</param>
public void CallInvokeUIUpdate(String code, object arg = null)
{
//创建一个委托,用于封装一个方法,在这里是封装了 控制更新控件 的方法
Action<String, object> invokeAction = new Action<String, object>(CallInvokeUIUpdate);
//判断操作控件的线程是否创建控件的线程
//调用方调用方位于创建控件所在的线程以外的线程中,如果在其他线程则对控件进行方法调用时必须调用 Invoke 方法
if (this.InvokeRequired)
{
//与调用线程不同的线程上创建(说明您必须通过 Invoke 方法对控件进行调用)
this.Invoke(invokeAction, code, arg);
}
else
{
//窗体线程,即主线程
switch (code)
{
//识别码
case "codeUpdateLaeleText":
//控件相关操作
lblTip.Text = "Label文本已更新";
lblTip.Text = arg.ToString();
break;
default:
break;
}
}
}
/// <summary>
/// 实现更新控件的接口
/// </summary>
/// <param name="control">需要更新的控件</param>
/// <param name="code">操作识别码</param>
/// <param name="arg">辅助参数</param>
public void CallInvokeUIUpdate(Control control, String code, object arg = null)
{
//创建一个委托,用于封装一个方法,在这里是封装了 控制更新控件 的方法
Action<Control, String, object> invokeAction = new Action<Control, String, object>(CallInvokeUIUpdate);
//判断操作控件的线程是否创建控件的线程
//调用方调用方位于创建控件所在的线程以外的线程中,如果在其他线程则对控件进行方法调用时必须调用 Invoke 方法
if (control.InvokeRequired)
{
//与调用线程不同的线程上创建(说明您必须通过 Invoke 方法对控件进行调用)
control.Invoke(invokeAction, code, arg);
}
else
{
//窗体线程,即主线程
switch (code)
{
//识别码
case "codeUpdateLaeleText":
//控件相关操作
control.Text = "Label文本已更新";
control.Text = arg.ToString();
break;
default:
break;
}
}
}