我有一个名为 ExecuteCommand 的函数,它根据用户的输入执行操作。这些事情的范围可以从简单地执行 Console.Writeline(),检查我的表单上的复选框,或者模拟对另一个进程的击键,完全独立于我自己的进程。该函数在单独的线程上运行,因此更改 UI 将需要一些调用。我有两种方法……我不确定其中一种方法是好方法,但它很容易。
下面的代码,第三行是我有一个问题:
private void ExecuteCommand()
{
this.Invoke((MethodInvoker)delegate()
{
if (current_line_index < command_que.Count)
{
current_line = command_que[current_line_index];
if (current_line.StartsWith(">>Auto Enter"))
{
chkAutoEnter.Checked = false;
}
else if (current_line.StartsWith("+WinWait("))
{
string title_to_wait_for = current_line;
title_to_wait_for = title_to_wait_for.Remove(0, "+WinWait(\"".Length);
title_to_wait_for = title_to_wait_for.Remove(title_to_wait_for.Length - 2, 2);
t_WinWait = new Thread(() => WinWait(title_to_wait_for));
t_WinWait.Name = "WinWait";
t_WinWait.Start();
}
}
});
}
该代码完美运行......但我不确定这是否是一种好习惯。
或者,我知道我可以做这样的事情来改变 UI:
private delegate void CheckCheckBoxHandler(bool checked);
private void CheckCheckBox(bool checked)
{
if (this.chkAutoEnter.InvokeRequired)
{
this.chkAutoEnter.Invoke(new CheckCheckBoxHandler(this.CheckCheckBox), checked);
}
else
{
chkAutoEnter.Checked = checked;
}
}
但由于我的表单上有多个控件将从另一个线程更改,因此我必须添加一堆函数来做到这一点,而不是第一个示例中的简单方法。
无论如何,第一种方式很糟糕吗?有没有我还没有遇到的风险?好像是真的……
谢谢!