如何在WPF 中非同步延遲操作
嘗試在操作中建立延遲時,使用Thread.Sleep 可能會導致UI 執行緒被阻塞。為了克服這個問題,應該採取非同步手段。
一種方法是使用DispatcherTimer:
<code class="csharp">tbkLabel.Text = "two seconds delay"; var timer = new DispatcherTimer { Interval = TimeSpan.FromSeconds(2) }; timer.Start(); timer.Tick += (sender, args) => { timer.Stop(); var page = new Page2(); page.Show(); };</code>
另一種方法是使用Task.Delay:
<code class="csharp">tbkLabel.Text = "two seconds delay"; Task.Delay(2000).ContinueWith(_ => { var page = new Page2(); page.Show(); });</code>
對於.NET 4.5 及更高版本,可以使用async/await:
<code class="csharp">// Add async keyword to the method signature public async void TheEnclosingMethod() { tbkLabel.Text = "two seconds delay"; await Task.Delay(2000); var page = new Page2(); page.Show(); }</code>
透過實作非同步方法,UI 執行緒在延遲期間保持回應,從而實現視窗之間的無縫轉換。
以上是如何在 WPF 中非同步延遲操作而不阻塞 UI 執行緒?的詳細內容。更多資訊請關注PHP中文網其他相關文章!