gpt4 book ai didi

c# - this.Invoke(...) - 这是不好的做法吗?

转载 作者:太空宇宙 更新时间:2023-11-03 20:14:10 26 4
gpt4 key购买 nike

我有一个名为 ExecuteCommand 的函数,它根据用户的输入执行操作。这些事情的范围很广,从简单地执行 Console.Writeline()、选中我的表单上的复选框,或者模拟击键到另一个过程,完全独立于我自己的过程。该函数在单独的线程上运行,因此更改 UI 将需要一些调用。我有 2 种方法...我不确定其中一种方法是否好,但它非常简单。

下面的代码,第 3 行是我有疑问的地方:

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();
}
}
});
}

代码运行完美……但我不确定这是否是好的做法。

或者,我知道我可以做这样的事情来改变用户界面:

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;
}
}

但由于我的表单上有多个控件将从另一个线程更改,因此我必须添加一堆函数来执行此操作,而不是第一个示例中的简单方法。

无论如何,第一种方式不好吗?是否有任何我尚未遇到的风险?这似乎是真的...

谢谢!

最佳答案

不,这还不错。您在哪个控件上调用 Invoke 并不重要,因为它们都具有相同的效果。 Invoke 在拥有控件的线程上调用委托(delegate) - 只要您的所有控件都属于同一个线程,就没有区别。

关于c# - this.Invoke(...) - 这是不好的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18028767/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com