委托BegionInvoke和窗体BegionInvoke
委托BegionInvoke是指通過委托方法執(zhí)行多線程任務(wù),例如:
//定義委托成員變量
delegate? void dg_DeleAirport();
//指定委托函數(shù)
dg_DeleAirport dga = AirportBLL.DeleteHistoryTransAirport;
//通過BeginInvoke以異步線程方式執(zhí)行委托函數(shù),可通過EndInvoke獲取返回值
//如果委托函數(shù)需要傳入?yún)?shù),這些傳入?yún)?shù)寫在下面的兩個null之前,
//這兩個參數(shù),第一個可指明回調(diào)函數(shù)名稱(函數(shù)本身可由參數(shù),但這里不寫參數(shù)),就是異步線程結(jié)束后主線程執(zhí)行的函數(shù),參數(shù)一般就是asrs,以便主線程處理返回結(jié)果,回調(diào)函數(shù)一般諸如xxxCompleted,且必須帶參數(shù)(IAsyncResult asrs),回調(diào)函數(shù)如:
void DelAirportCompleted(IAsyncResult df)
{
???? if (df != null)
??????????? {
??????????????? string cc=(df.AsyncState as dg_DeleAirport).EndInvoke(df).ToString();
??????????? }
??????????? inprocess = false;
}
//第二個參數(shù)表示第一個參數(shù)代表的值,往往就是調(diào)用者本身,如下句的dga。
IAsyncResult asrs = dga.BeginInvoke(null, null);
//此時,主線程將直接執(zhí)行后續(xù)代碼,不會等待委托函數(shù)執(zhí)行完畢。但是,可以通過EndInvoke或asrs.IsCompleted等阻塞函數(shù)進(jìn)行強制等待委托函數(shù)完成,
//EndInvoke()函數(shù)可稱為阻塞函數(shù),阻止主進(jìn)程繼續(xù)往下進(jìn)行直到異步線程完成。
//EndInvoke取回委托函數(shù)返回值,返回類型跟委托的類型一樣,如果委托函數(shù)返回類型是void,此函數(shù)的返回值也是void
while(!asrs.IsCompleted())一樣也可以起到強制主線程等待的作用,而且還可以在while方法中讓主線程做些等待相關(guān)的操作
dga.EndInvoke(asrs);
while (!asrs.IsCompleted)
{
}
此外,還可通過asrs.AsyncWaitHandle.WaitOne(5000, false);設(shè)置等待時間,無論是否完成,在等待時間后,繼續(xù)往下進(jìn)行。第一個參數(shù)表示等待毫秒數(shù)時間,在指定時間內(nèi)如果異步線程完成,返回true,否則false。
不建議使用阻塞函數(shù),因為主界面會假死,跟不用多線程沒有區(qū)別。
轉(zhuǎn)載于:https://www.cnblogs.com/mol1995/p/7614820.html
總結(jié)
以上是生活随笔為你收集整理的委托BegionInvoke和窗体BegionInvoke的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Controller计算值传到jsp页面
- 下一篇: mybatis对java自定义注解的使用