C#--耗時操作實現(xiàn)UI界面實時更新不阻塞(耗時操作解決窗體卡頓)
當前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
前言C#實現(xiàn)窗體加載進度條或者百分比實時顯示耗時操作的進度,方法有很多。但是經(jīng)過我的學(xué)習(xí)、查找與實際應(yīng)用,發(fā)現(xiàn)Task配合MethodInvoker最為高效便捷。下面我就來結(jié)合代碼講一下要注意的問題。 基礎(chǔ)知識C#在winform上進行耗時操作往往會放置progressbar,問題是在UI線程上進行耗時操作就會導(dǎo)致UI線程阻塞,界面就會卡頓。所以勢必要另開一個線程進行耗時操作,之后將耗時操作的過程實時反饋給UI線程即可,可問題是新開的線程向UI線程傳遞數(shù)據(jù)的時候,就會出現(xiàn)經(jīng)典報錯: InvalidOperationException,并提示消息:“從不是創(chuàng)建控件的線程訪問它。 這是因為NET原則上禁止跨線程訪問。因為這樣可能造成錯誤的發(fā)生,有一種簡單粗暴的方法是禁止編譯器對跨線程訪問作檢查,Control.CheckForIllegalCrossThreadCalls = false;可以實現(xiàn)訪問,但是什么時候出錯不敢保證。 TaskTask是一個升級版本的Thread的類,它非常的靈活,支持取消、阻塞等待、合并、多個Task協(xié)同操作......??傊褂肨ask編碼高效易懂,你基本不用去研究Thread與ThreadPool了,雖然本質(zhì)上還是這個。我個人理解Task就是對Thread的再次封裝。 MethodInvokerMethodInvoker 是位于System.Windows.Forms下的元數(shù)據(jù),表示一個委托,該委托可以執(zhí)行托管代碼中聲明為void且不接受任何參數(shù)的任何方法。在對控件的 invoke 方法進行調(diào)用時或需要一個簡單委托又不想自己定義時可以使用該委托。 我是這樣理解的,在新線程中使用 MethodInvoker 委托執(zhí)行耗時操作, 其實相當于是在主線程中執(zhí)行的,這樣就避免了跨線程訪問控件。 示例代碼
線程的延續(xù)采用ContinueWith解決 BeginInvoke解決界面的刷新問題 TaskScheduler.FromCurrentSynchronizationContext() 解決跨線程訪問報錯
button2的方式可以在task線程中按順序執(zhí)行耗時操作。 該文章在 2024/11/27 18:53:32 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |