gpt4 book ai didi

c# - BeginInvoke 未在 WPF 应用程序的线程内触发

转载 作者:行者123 更新时间:2023-11-30 14:00:20 27 4
gpt4 key购买 nike

我在 WPF 应用程序中有这个简单的代码:

ThreadStart start = delegate()
{
Thread.Sleep(5000);
Console.WriteLine("HEY!");

Dispatcher.CurrentDispatcher.BeginInvoke(
DispatcherPriority.Normal,
new Action(
delegate()
{
Console.WriteLine("Inside invoke?!");
}
)
);
};

new Thread(start).Start();

嘿! 会在片刻后正常打印,并且应用程序不会像使用线程所期望的那样被阻塞,但是,为什么我从来没有看到内部调用?!?我还尝试了不同的优先级,例如 Send,我认为这是最高优先级。

我也试过在里面放断点,但它从未停在那里。

最佳答案

先了解一些基础知识 -

  • 每个线程都有自己的 Dispatcher 和 Dispatcher。CurrentDispatcher 将始终返回当前正在执行的线程的 Dispatcher。
  • BeginInvoke 根据 DispatcherPriority 指定的优先级异步执行您指定的委托(delegate)。

代码问题 -您正在将委托(delegate)放置在您创建的辅助线程的 Dispatcher 队列中。但是在辅助线程有时间执行它之前,您的辅助线程退出了,因此它的调度程序也退出了。这就是委托(delegate)永远不会被执行的原因。

有两种方法可以实现这一点-

像这样在调度程序上同步地排队委托(delegate) -

Dispatcher.CurrentDispatcher.Invoke(
DispatcherPriority.Normal,
new Action(
delegate()
{
Console.WriteLine("Inside invoke?!");
}
)
);

或者您可以像这样在主线程(通常称为 UI 线程)的调度程序上将其排队 -

Application.Current.Dispatcher.BeginInvoke(
DispatcherPriority.Normal,
new Action(
delegate()
{
Console.WriteLine("Inside invoke?!");
}
)
);

关于c# - BeginInvoke 未在 WPF 应用程序的线程内触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11178334/

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