精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

異步編程:基于事件的異步編程模式(EMP)

開發(fā) 后端
對于相對簡單的多線程應(yīng)用程序,BackgroundWorker組件提供了一個簡單的解決方案。對于更復(fù)雜的異步應(yīng)用程序,可以考慮實現(xiàn)一個符合基于事件的異步模式的類。

上一篇,我給大家介紹了“.NET1.0中基于IAsyncResult設(shè)計模式的異步編程模型(APM)”,它使用System.Threading命名空間的類來構(gòu)造多線程應(yīng)用程序。然而要想有效地使用這些工具類,需要有豐富的使用多線程軟件工程的經(jīng)驗。對于相對簡單的多線程應(yīng)用程序,BackgroundWorker組件提供了一個簡單的解決方案。對于更復(fù)雜的異步應(yīng)用程序,可以考慮實現(xiàn)一個符合基于事件的異步模式的類。

使用支持此模式的類,您將能夠:

1) 異步執(zhí)行耗時的任務(wù)。

2) 獲得進度報告和增量結(jié)果。

3) 支持耗時任務(wù)的取消。

4) 獲得任務(wù)的結(jié)果值或異常信息。

5) 更復(fù)雜:支持同時執(zhí)行多個異步操作、進度報告、增量結(jié)果、取消操作、返回結(jié)果值或異常信息。

 

 

源碼下載:異步編程:基于事件的異步模型(EAP).rar

 

為了實現(xiàn)基于事件的異步模式,我們必須先理解兩個重要的幫助器類:

 

AsyncOperationManager和AsyncOperation

AsyncOperationManager類和AsyncOperation類是System.ComponentModel命名空間為我們提供了兩個重要幫助器類。在基于事件的異步模式封裝標(biāo)準(zhǔn)化的異步功能中,它確保你的異步操作支持在各種應(yīng)用程序模型(包括 ASP.NET、控制臺應(yīng)用程序和 Windows 窗體應(yīng)用程序)的適當(dāng)“線程或上下文”調(diào)用客戶端事件處理程序。

AsyncOperationManager類和AsyncOperation類的API如下:

  1. // 為支持異步方法調(diào)用的類提供并發(fā)管理。此類不能被繼承。  
  2. public static class AsyncOperationManager  
  3. {  
  4.     // 獲取或設(shè)置用于異步操作的同步上下文。  
  5.     public static SynchronizationContext SynchronizationContext { get; set; }  
  6.    
  7.     // 返回可用于對特定異步操作的持續(xù)時間進行跟蹤的AsyncOperation對象。  
  8.     // 參數(shù):userSuppliedState:  
  9.     //     一個對象,用于使一個客戶端狀態(tài)(如任務(wù) ID)與一個特定異步操作相關(guān)聯(lián)。  
  10.     public static AsyncOperation CreateOperation(object userSuppliedState)  
  11.     {  
  12.         return AsyncOperation.CreateOperation(userSuppliedState,SynchronizationContext);  
  13.     }  
  14. }  
  15.    
  16. // 跟蹤異步操作的生存期。  
  17. public sealed class AsyncOperation  
  18. {  
  19.     // 構(gòu)造函數(shù)  
  20.     private AsyncOperation(object userSuppliedState, SynchronizationContext syncContext);  
  21.     internal static AsyncOperation CreateOperation(object userSuppliedState  
  22.                                             , SynchronizationContext syncContext);  
  23.    
  24.     // 獲取傳遞給構(gòu)造函數(shù)的SynchronizationContext對象。  
  25.     public SynchronizationContext SynchronizationContext { get; }  
  26.     // 獲取或設(shè)置用于唯一標(biāo)識異步操作的對象。  
  27.     public object UserSuppliedState { get; }  
  28.    
  29.     // 在各種應(yīng)用程序模型適合的線程或上下文中調(diào)用委托。  
  30.     public void Post(SendOrPostCallback d, object arg);  
  31.     // 結(jié)束異步操作的生存期。  
  32.     public void OperationCompleted();  
  33.     // 效果同調(diào)用 Post() + OperationCompleted() 方法組合  
  34.     public void PostOperationCompleted(SendOrPostCallback d, object arg);  

先分析下這兩個幫助器類:

1. AsyncOperationManager是靜態(tài)類。靜態(tài)類是密封的,因此不可被繼承。倘若從靜態(tài)類繼承會報錯“靜態(tài)類必須從 Object 派生”。(小常識,以前以為密封類就是 sealed 關(guān)鍵字)

2. AsyncOperationManager為支持異步方法調(diào)用的類提供并發(fā)管理,該類可正常運行于 .NET Framework 支持的所有應(yīng)用程序模式下。

3. AsyncOperation實例提供對特定異步任務(wù)的生存期進行跟蹤。可用來處理任務(wù)完成通知,還可用于在不終止異步操作的情況下發(fā)布進度報告和增量結(jié)果(這種不終止異步操作的處理是通過AsyncOperation的 Post() 方法實現(xiàn))。

4. AsyncOperation類有一個私有的構(gòu)造函數(shù)和一個內(nèi)部CreateOperation() 靜態(tài)方法。由AsyncOperationManager類調(diào)用AsyncOperation.CreateOperation() 靜態(tài)方法來創(chuàng)建AsyncOperation實例。

5. AsyncOperation類是通過SynchronizationContext類來實現(xiàn)在各種應(yīng)用程序的適當(dāng)“線程或上下文”調(diào)用客戶端事件處理程序。

  1. // 提供在各種同步模型中傳播同步上下文的基本功能。  
  2. public class SynchronizationContext  
  3. {  
  4.     // 獲取當(dāng)前線程的同步上下文。  
  5.     public static SynchronizationContext Current { get; }  
  6.    
  7.     // 當(dāng)在派生類中重寫時,響應(yīng)操作已開始的通知。  
  8.     public virtual void OperationStarted();  
  9.     // 當(dāng)在派生類中重寫時,將異步消息調(diào)度到一個同步上下文。  
  10.     public virtual void Post(SendOrPostCallback d, object state);  
  11.     // 當(dāng)在派生類中重寫時,響應(yīng)操作已完成的通知。  
  12.     public virtual void OperationCompleted();  
  13.     ……  

a) 在AsyncOperation構(gòu)造函數(shù)中調(diào)用SynchronizationContext的OperationStarted() ;

b) 在AsyncOperation的 Post() 方法中調(diào)用SynchronizationContext的Post() ;

c) 在AsyncOperation的OperationCompleted()方法中調(diào)用SynchronizationContext的OperationCompleted();

6. SendOrPostCallback委托簽名:

  1. // 表示在消息即將被調(diào)度到同步上下文時要調(diào)用的方法。  
  2. public delegate void SendOrPostCallback(object state); 

#p#

基于事件的異步模式的特征

1. 基于事件的異步模式可以采用多種形式,具體取決于某個特定類支持操作的復(fù)雜程度:

1) 最簡單的類可能只有一個 ***Async方法和一個對應(yīng)的 ***Completed 事件,以及這些方法的同步版本。

2) 復(fù)雜的類可能有若干個 ***Async方法,每種方法都有一個對應(yīng)的 ***Completed 事件,以及這些方法的同步版本。

3) 更復(fù)雜的類還可能為每個異步方法支持取消(CancelAsync()方法)、進度報告和增量結(jié)果(ReportProgress() 方法+ProgressChanged事件)。

4) 如果您的類支持多個異步方法,每個異步方法返回不同類型的數(shù)據(jù),您應(yīng)該:

a) 將您的增量結(jié)果報告與您的進度報告分開。

b) 使用適當(dāng)?shù)腅ventArgs為每個異步方法定義一個單獨的 ***ProgressChanged事件以處理該方法的增量結(jié)果數(shù)據(jù)。

5) 如果類不支持多個并發(fā)調(diào)用,請考慮公開IsBusy屬性。

6) 如要異步操作的同步版本中有 Out 和 Ref 參數(shù),它們應(yīng)做為對應(yīng) ***CompletedEventArgs的一部分,eg:

  1. public int MethodName(string arg1, ref string arg2, out string arg3);  
  2.    
  3. public void MethodNameAsync(string arg1, string arg2);  
  4. public class MethodNameCompletedEventArgs : AsyncCompletedEventArgs  
  5. {  
  6.     public int Result { get; };  
  7.     public string Arg2 { get; };  
  8.     public string Arg3 { get; };  

2. 如果你的組件要支持多個異步耗時的任務(wù)并行執(zhí)行。那么:

1) 為***Async方法多添加一個userState對象參數(shù)(此參數(shù)應(yīng)當(dāng)始終是***Async方法簽名中的最后一個參數(shù)),用于跟蹤各個操作的生存期。

2) 注意要在你構(gòu)建的異步類中維護一個userState對象的集合。使用 lock 區(qū)域保護此集合,因為各種調(diào)用都會在此集合中添加和移除userState對象。

3) 在***Async方法開始時調(diào)用AsyncOperationManager.CreateOperation并傳入userState對象,為每個異步任務(wù)創(chuàng)建AsyncOperation對象,userState存儲在AsyncOperation的UserSuppliedState屬性中。在構(gòu)建的異步類中使用該屬性標(biāo)識取消的操作,并傳遞給CompletedEventArgs和ProgressChangedEventArgs參數(shù)的UserState屬性來標(biāo)識當(dāng)前引發(fā)進度或完成事件的特定異步任務(wù)。

4) 當(dāng)對應(yīng)于此userState對象的任務(wù)引發(fā)完成事件時,你構(gòu)建的異步類應(yīng)將AsyncCompletedEventArgs.UserState對象從集合中刪除。

3. 注意:

1) 確保 ***EventArgs類特定于***方法。即當(dāng)使用 ***EventArgs類時,切勿要求開發(fā)人員強制轉(zhuǎn)換類型值。

2) 確保始終引發(fā)方法名稱Completed 事件。成功完成、異常或者取消時應(yīng)引發(fā)此事件。任何情況下,應(yīng)用程序都不應(yīng)遇到這樣的情況:應(yīng)用程序保持空閑狀態(tài),而操作卻一直不能完成。

3) 確保可以捕獲異步操作中發(fā)生的任何異常并將捕獲的異常指派給 Error 屬性。

4) 確保 ***CompletedEventArgs 類將其成員公開為只讀屬性而不是字段,因為字段會阻止數(shù)據(jù)綁定。eg:public MyReturnType Result { get; }

5) 在構(gòu)建 ***CompletedEventArgs 類屬性時,通過this.RaiseExceptionIfNecessary() 方法確保屬性值被正確使用。Eg:

  1. public int MethodName(string arg1, ref string arg2, out string arg3);  
  2.    
  3. public void MethodNameAsync(string arg1, string arg2);  
  4. public class MethodNameCompletedEventArgs : AsyncCompletedEventArgs  
  5. {  
  6.     public int Result { get; };  
  7.     public string Arg2 { get; };  
  8.     public string Arg3 { get; };  

2. 如果你的組件要支持多個異步耗時的任務(wù)并行執(zhí)行。那么:

1) 為***Async方法多添加一個userState對象參數(shù)(此參數(shù)應(yīng)當(dāng)始終是***Async方法簽名中的最后一個參數(shù)),用于跟蹤各個操作的生存期。

2) 注意要在你構(gòu)建的異步類中維護一個userState對象的集合。使用 lock 區(qū)域保護此集合,因為各種調(diào)用都會在此集合中添加和移除userState對象。

3) 在***Async方法開始時調(diào)用AsyncOperationManager.CreateOperation并傳入userState對象,為每個異步任務(wù)創(chuàng)建AsyncOperation對象,userState存儲在AsyncOperation的UserSuppliedState屬性中。在構(gòu)建的異步類中使用該屬性標(biāo)識取消的操作,并傳遞給CompletedEventArgs和ProgressChangedEventArgs參數(shù)的UserState屬性來標(biāo)識當(dāng)前引發(fā)進度或完成事件的特定異步任務(wù)。

4) 當(dāng)對應(yīng)于此userState對象的任務(wù)引發(fā)完成事件時,你構(gòu)建的異步類應(yīng)將AsyncCompletedEventArgs.UserState對象從集合中刪除。

3. 注意:

1) 確保 ***EventArgs類特定于***方法。即當(dāng)使用 ***EventArgs類時,切勿要求開發(fā)人員強制轉(zhuǎn)換類型值。

2) 確保始終引發(fā)方法名稱Completed 事件。成功完成、異常或者取消時應(yīng)引發(fā)此事件。任何情況下,應(yīng)用程序都不應(yīng)遇到這樣的情況:應(yīng)用程序保持空閑狀態(tài),而操作卻一直不能完成。

3) 確保可以捕獲異步操作中發(fā)生的任何異常并將捕獲的異常指派給 Error 屬性。

4) 確保 ***CompletedEventArgs 類將其成員公開為只讀屬性而不是字段,因為字段會阻止數(shù)據(jù)綁定。eg:public MyReturnType Result { get; }

5) 在構(gòu)建 ***CompletedEventArgs 類屬性時,通過this.RaiseExceptionIfNecessary() 方法確保屬性值被正確使用。Eg:

  1. private bool isPrimeValue;  
  2. public bool IsPrime  
  3. {  
  4.     get  
  5.     {  
  6.         RaiseExceptionIfNecessary();  
  7.         return isPrimeValue;  
  8.     }  

所以,在***Completed事件處理程序中,應(yīng)當(dāng)總是先檢查 ***CompletedEventArgs.Error 和 ***CompletedEventArgs.Cancelled 屬性,然后再訪問RunWorkerCompletedEventArgs.Result屬性。

#p#

BackgroundWorker組件

System.ComponentModel命名空間的BackgroundWorker組件為我們提供了一個簡單的多線程應(yīng)用解決方案,它允許你在單獨的線程上運行耗時操作而不會導(dǎo)致用戶界面的阻塞。但是,要注意它同一時刻只能運行一個異步耗時操作(使用IsBusy屬性判定),并且不能跨AppDomain邊界進行封送處理(不能在多個AppDomain中執(zhí)行多線程操作)。

1. BackgroundWorker組件

  1. public class BackgroundWorker : Component  
  2. {  
  3.     public BackgroundWorker();  
  4.    
  5.     // 獲取一個值,指示應(yīng)用程序是否已請求取消后臺操作。  
  6.     public bool CancellationPending { get; }  
  7.     // 獲取一個值,指示BackgroundWorker是否正在運行異步操作。  
  8.     public bool IsBusy { get; }  
  9.     // 獲取或設(shè)置一個值,該值指示BackgroundWorker能否報告進度更新。  
  10.     public bool WorkerReportsProgress { get; set; }  
  11.     // 獲取或設(shè)置一個值,該值指示BackgroundWorker是否支持異步取消。  
  12.     public bool WorkerSupportsCancellation { get; set; }  
  13.    
  14.     // 調(diào)用RunWorkerAsync() 時發(fā)生。  
  15.     public event DoWorkEventHandlerDoWork;  
  16.     // 調(diào)用ReportProgress(System.Int32) 時發(fā)生。  
  17.     public event ProgressChangedEventHandlerProgressChanged;  
  18.     // 當(dāng)后臺操作已完成、被取消或引發(fā)異常時發(fā)生。  
  19.     public event RunWorkerCompletedEventHandlerRunWorkerCompleted;  
  20.    
  21.     // 請求取消掛起的后臺操作。  
  22.     public void CancelAsync();  
  23.     // 引發(fā)ProgressChanged事件。percentProgress:范圍從 0% 到 100%  
  24.     public void ReportProgress(int percentProgress);  
  25.     // userState:傳遞到RunWorkerAsync(System.Object) 的狀態(tài)對象。  
  26.     public void ReportProgress(int percentProgress, object userState);  
  27.     // 開始執(zhí)行后臺操作。  
  28.     public void RunWorkerAsync();  
  29.     // 開始執(zhí)行后臺操作。argument:傳遞給DoWork事件的DoWorkEventArgs參數(shù)。  
  30.     public void RunWorkerAsync(object argument);  

2. 相應(yīng)的EventArgs類

  1. ///1)   System.EventArgs基類  
  2.     // System.EventArgs是包含事件數(shù)據(jù)的類的基類。  
  3.     public class EventArgs  
  4.     {  
  5.         // 表示沒有事件數(shù)據(jù)的事件。  
  6.         public static readonly EventArgs Empty;  
  7.         public EventArgs();  
  8.     }  
  9.    
  10. ///2)   DoWorkEventArgs類  
  11.     // 為可取消的事件提供數(shù)據(jù)。  
  12.     public class CancelEventArgs : EventArgs  
  13.     {  
  14.         public CancelEventArgs();  
  15.         public CancelEventArgs(bool cancel);  
  16.         // 獲取或設(shè)置指示是否應(yīng)取消事件的值。  
  17.         public bool Cancel { get; set; }  
  18.     }  
  19.     // 為DoWork事件處理程序提供數(shù)據(jù)。  
  20.     public class DoWorkEventArgs : CancelEventArgs  
  21.     {  
  22.         public DoWorkEventArgs(object argument);  
  23.    
  24.         // 獲取表示異步操作參數(shù)的值。  
  25.         public object Argument { get; }  
  26.         // 獲取或設(shè)置表示異步操作結(jié)果的值。  
  27.         public object Result { get; set; }  
  28.     }  
  29.    
  30. ///3)   ProgressChangedEventArgs類  
  31.     // 為ProgressChanged事件提供數(shù)據(jù)。  
  32.     public class ProgressChangedEventArgs : EventArgs  
  33.     {  
  34.         public ProgressChangedEventArgs(int progressPercentage, object userState);  
  35.    
  36.         // 獲取異步任務(wù)的進度百分比。  
  37.         public int ProgressPercentage { get; }  
  38.         // 獲取唯一的用戶狀態(tài)。  
  39.         public object UserState { get; }  
  40.     }  
  41.    
  42. ///4)   RunWorkerCompletedEventArgs類  
  43.     // 為MethodNameCompleted事件提供數(shù)據(jù)。  
  44.     public class AsyncCompletedEventArgs : EventArgs  
  45.     {  
  46.         public AsyncCompletedEventArgs();  
  47.         public AsyncCompletedEventArgs(Exception error, bool cancelled, object userState);  
  48.    
  49.         // 獲取一個值,該值指示異步操作是否已被取消。  
  50.         public bool Cancelled { get; }  
  51.         // 獲取一個值,該值指示異步操作期間發(fā)生的錯誤。  
  52.         public Exception Error { get; }  
  53.         // 獲取異步任務(wù)的唯一標(biāo)識符。  
  54.         public object UserState { get; }  
  55.    
  56.         // 訪問 AsyncCompletedEventArgs 及其派生類的屬性前調(diào)用此方法  
  57.         protected void RaiseExceptionIfNecessary()  
  58.         {  
  59.             if (this.Error != null)  
  60.             {  
  61.                 throw new TargetInvocationException(……);  
  62.             }  
  63.             if (this.Cancelled)  
  64.             {  
  65.                 throw new InvalidOperationException(……);  
  66.             }  
  67.         }  
  68.     }  
  69.     public class RunWorkerCompletedEventArgs : AsyncCompletedEventArgs  
  70.     {  
  71.         public RunWorkerCompletedEventArgs(object result, Exception error, bool cancelled);  
  72.    
  73.         // 獲取表示異步操作結(jié)果的值。  
  74.         public object Result { get; }  
  75.         // 獲取表示用戶狀態(tài)的值。  
  76.         public object UserState { get; }  
  77.     } 
3.   BackgroundWorker示例

示例代碼中包含了BackgroundWorker源代碼及對應(yīng)的使用示例,這里不粘貼代碼了,會導(dǎo)致篇幅更大。來個示例截圖吧:

image

示例分析:

1)   首先我們?yōu)锽ackgroundWorker組件注冊DoWork(異步操作)、ProgressChanged(進度報告) 和RunWorkCompleted(完成通知)事件;

2)   設(shè)置WorkerSupportsCancellation和WorkerReportsProgress屬性為true,以聲明組件支持取消操作和進度報告;

3)   使用RunWorkerAsync() 開啟異步操作,通過IsBusy屬性判斷是否已經(jīng)有異步任務(wù)在執(zhí)行;

4)   使用CancelAsync() 方法取消異步操作,但要注意:

a)   它僅僅是將BackgroudWorker.CancellationPending屬性設(shè)置為true。需要在具體DoWork事件中不斷檢查BackgroudWorker.CancellationPending來設(shè)置DoWorkEventArgs的Cancel屬性。

b)   DoWork事件處理程序中的代碼有可能在發(fā)出取消請求時完成其工作,輪詢循環(huán)可能會錯過設(shè)置為 true 的CancellationPending屬性。在這種情況下,即使發(fā)出了取消請求,RunWorkerCompleted事件處理程序中RunWorkerCompletedEventArgs的 Cancelled 標(biāo)志也不會設(shè)置為 true。這種情況被稱作爭用狀態(tài)。(可以通過直接監(jiān)控組件的CancellationPending屬性,來做判斷)

5)   確保在DoWork事件處理程序中不操作任何用戶界面對象。而應(yīng)該通過ProgressChanged和RunWorkerCompleted事件與用戶界面進行通信。

因為RunWorkerAsync() 是通過委托的BeginInvoke() 引發(fā)的DoWork事件,即DoWork事件的執(zhí)行線程已不是創(chuàng)建控件的線程(我在《異步編程:異步編程模型 (APM)》中介紹了幾種夸線程訪問控件的方式)。而ProgressChanged和RunWorkerCompleted事件是通過幫助器類AsyncOperation的 Post() 方法使其調(diào)用發(fā)生在合適的“線程或上下文”中。

#p#

自定義基于事件的異步組件

剛才我們介紹了BackgroundWorker組件,但是這個組件在一個時刻只能開啟一個異步操作,那如果我們要想同時支持多個異步操作、進度報告、增量結(jié)果、取消和返回結(jié)果值或異常信息該怎么辦呢?對的,我們可以為自己定義一個基于事件的異步組件。

我直接引用MSDN上的一則計算質(zhì)數(shù)的異步組件示例,請從我提供的示例代碼中獲取。

質(zhì)數(shù)算法:埃拉托色尼篩法

eg:判斷n是否為質(zhì)數(shù)

1、1和0既非素數(shù)也非合數(shù);

2、將2和3加入質(zhì)數(shù)集合primes;從n=5開始,通過 n+=2 來跳過所有偶數(shù);

3、循環(huán)集合primes中的質(zhì)數(shù)并將其做為n的因子,能整除的為合數(shù);

4、若不能整除,則繼續(xù)循步驟3直到“因子的平方>n”,即可判斷n為質(zhì)數(shù),并將其加入到集合primes。


 

來個示例截圖吧:

image

示例分析:(組件名:PrimeNumberCalculator)

1.   首先我們?yōu)镻rimeNumberCalculator組件注冊ProgressChanged(進度報告) 和CalculatePrimeCompleted(完成通知)事件;

2.   使用CalculatePrimeAsync(intnumberToTest, object taskId)開啟異步任務(wù),注意我們需要傳遞一個唯一標(biāo)識Guid taskId = Guid.NewGuid();用于標(biāo)識取消的操作,并傳遞給CompletedEventArgs和ProgressChangedEventArgs參數(shù)的UserState屬性來標(biāo)識當(dāng)前引發(fā)進度或完成事件的特定異步任務(wù);

3.   取消操作CancelAsync(object taskId),只是將taskId對應(yīng)的AsyncOperation實例移除內(nèi)部任務(wù)集合,耗時操作通過判斷taskId是否存在于集合來判斷其是否被取消;

此文到此結(jié)束,通過此博文我們認(rèn)識到:

1)   基于事件的異步編程是通過AsyncOperationManager類和AsyncOperation類兩個幫助器類確保你的異步操作支持在各種應(yīng)用程序模型(包括 ASP.NET、控制臺應(yīng)用程序和 Windows 窗體應(yīng)用程序)的適當(dāng)“線程或上下文”調(diào)用訪問控件;

2)   BackgroundWorker組件構(gòu)建、使用和缺點。

3)   展現(xiàn)如何構(gòu)建一個基于事件的異步組件,并且支持多個異步操作的并行運行

感謝大家的觀賞,如本文對你有幫助還請多幫推薦支持下……

原文鏈接:http://www.cnblogs.com/heyuquan/archive/2013/04/01/2993085.html

責(zé)任編輯:林師授 來源: 博客園
相關(guān)推薦

2009-08-20 17:47:54

C#異步編程模式

2013-03-08 09:33:25

JavaScript同步異步

2013-04-01 15:38:54

異步編程異步編程模型

2011-02-22 09:09:21

.NETAsync CTP異步

2011-02-22 08:49:16

.NET同步異步

2020-10-15 13:29:57

javascript

2009-08-20 17:30:56

C#異步編程模式

2015-09-07 14:08:32

Java編程異步事件

2017-07-13 12:12:19

前端JavaScript異步編程

2016-09-07 20:43:36

Javascript異步編程

2015-04-22 10:50:18

JavascriptJavascript異

2014-05-23 10:12:20

Javascript異步編程

2010-04-06 15:20:56

ASP.NET MVC

2024-04-01 09:45:50

TAP模式.NET異步編程

2017-08-02 15:00:12

PythonAsyncio異步編程

2021-08-02 11:13:28

人工智能機器學(xué)習(xí)技術(shù)

2021-12-10 07:47:30

Javascript異步編程

2017-05-05 08:44:24

PythonAsyncio異步編程

2011-11-11 15:47:22

JavaScript

2016-12-30 13:43:35

異步編程RxJava
點贊
收藏

51CTO技術(shù)棧公眾號

国产乱码精品一区二区三区亚洲人| 天堂√在线中文官网在线| 99热国内精品永久免费观看| 69久久99精品久久久久婷婷 | 91高清免费在线观看| 女尊高h男高潮呻吟| 国产91欧美| 一区二区三区中文字幕在线观看| 精品国产综合区久久久久久| 中文字幕一区二区三区人妻四季| 欧美成人日本| 国产一区二区免费| 亚洲 自拍 另类 欧美 丝袜| 美女100%一区| 亚洲一区二区三区影院| 日韩欧美亚洲精品| 丰满人妻妇伦又伦精品国产| 久久亚洲二区| 欧美巨乳美女视频| 日韩一级av毛片| 视频精品一区二区三区| 色婷婷av一区二区三区gif| 女女百合国产免费网站| 麻豆app在线观看| 国产精品1024| 国产精品永久在线| 激情五月婷婷在线| 日韩成人激情| 亚洲精品永久免费精品| 久久av一区二区三| 婷婷久久免费视频| 91国偷自产一区二区三区观看 | 久久精品日产第一区二区三区| 在线观看不卡的av| 亚洲男女自偷自拍| 欧美黑人性猛交| 免费黄色激情视频| 精品欧美激情在线观看| 亚洲黄色成人网| 一起草最新网址| 欧美xxxx网站| 在线观看亚洲一区| 一本大道熟女人妻中文字幕在线 | 国产精品av网站| 国产 日韩 欧美 在线| 欧美激情偷拍| 久久精品99国产精品酒店日本| mm131丰满少妇人体欣赏图| 欧美一级全黄| 亚洲精品av在线| 人妻 丝袜美腿 中文字幕| av日韩久久| 欧美电影一区二区三区| 亚洲精品手机在线观看| 国产精品久久久久77777丨| 日韩欧美成人免费视频| 国模吧无码一区二区三区| 久草在线视频资源| 一区二区三区不卡视频在线观看 | 国产伦精品一区二区三区高清| 精品国精品国产自在久不卡| 国产精品一二三四五| 91亚洲精品久久久| 99久久久无码国产精品免费| 国产一区在线看| 97碰碰视频| 亚洲精品中文字幕成人片 | 国产精品成人一区二区三区| 精品人妻无码一区二区三区蜜桃一| 国产一区二区三区免费播放| 97人人模人人爽视频一区二区| 精品国产av一区二区三区| 国产福利精品一区二区| 国产成人免费观看| 天天射天天色天天干| 91香蕉视频在线| 日韩欧美精品一区二区三区经典| 亚洲搞黄视频| 怡红院av一区二区三区| aa视频在线播放| 日韩脚交footjobhdboots| 狠狠干狠狠久久| 五月婷婷狠狠操| 国产一区二区| 日韩成人av网| 极品美妇后花庭翘臀娇吟小说| 欧美日韩91| 日本久久久久久久| 97久久人国产精品婷婷| 不卡一卡二卡三乱码免费网站| 欧美日韩在线高清| 免费网站黄在线观看| 亚洲精选免费视频| 岳毛多又紧做起爽| 国产精品一区免费在线| 日韩高清人体午夜| 久久久久久久麻豆| 一区二区三区福利| 成人啪啪免费看| 天天操天天干天天舔| 欧美激情在线一区二区| 欧美这里只有精品| 欧美日韩女优| 亚洲国产日韩欧美在线99| 五月天免费网站| 一区二区高清| 99国产在线视频| 国产天堂在线| 亚洲成人精品一区| 一本色道久久亚洲综合精品蜜桃 | 亚洲日穴在线视频| 国产做受高潮69| 欧美 日韩 国产精品| xxx.xxx欧美| 色狠狠色噜噜噜综合网| 免费成人黄色大片| 亚洲精品国模| 一区三区二区视频| 精品在线视频观看| 另类成人小视频在线| 国产午夜精品在线| avtt亚洲| 欧美视频在线视频| 在线视频日韩欧美| 日韩高清一级| 欧美高清视频免费观看| 中文字幕+乱码+中文| 风流少妇一区二区| 在线观看亚洲视频啊啊啊啊| 神马午夜在线视频| 欧美一区二区三区视频在线| xxxx黄色片| 自拍日韩欧美| 国产精品露脸av在线| 亚洲精品久久久久久久久久久久久久 | 日韩视频亚洲视频| 日韩精品视频免费播放| 免费成人av在线| 欧美xxxx黑人又粗又长密月| 黄页网站在线观看免费| 欧美日韩中文字幕精品| 中出视频在线观看| 精品1区2区3区4区| 91九色对白| 午夜视频在线看| 色综合视频在线观看| 变态另类丨国产精品| 女人天堂亚洲aⅴ在线观看| 国产精品久久久久免费a∨| 五月激情丁香婷婷| 一区二区三区精品在线| 国产xxxxhd| 成人在线免费观看91| 国产va免费精品高清在线| www.五月激情| 亚洲精品国产a久久久久久 | 亚洲国产成人精品激情在线| 国产大陆精品国产| 大地资源网在线观看免费官网| 久久er热在这里只有精品66| 中文综合在线观看| 亚洲高清在线看| 国产免费成人在线视频| 青青在线视频免费| 免费久久久久久久久| 欧美在线观看视频| 日本福利片在线| 欧美中文字幕一二三区视频| 一区二区三区久久久久| 久久在线精品| 相泽南亚洲一区二区在线播放| 深夜视频一区二区| 最近2019中文字幕一页二页 | 色欧美激情视频在线| 日本黄色一区二区| 黄免费在线观看| 视频一区在线播放| 亚洲国产精品久久久久婷婷老年| 国产综合色在线观看| 视频一区视频二区国产精品| 欧美尤物一区| 国产素人视频在线观看| 日韩欧美激情一区| 日本三级片在线观看| 99久久久精品| 日韩中文字幕组| 日韩久久视频| 91网在线免费观看| av在线最新| 夜夜嗨av色综合久久久综合网| 波多野结衣不卡| 日韩美女视频一区二区 | 亚洲插插视频| 一区二区三区动漫| 国产露脸国语对白在线| 亚洲成人你懂的| 一区二区视频观看| 日韩福利电影在线观看| 自拍偷拍一区二区三区| baoyu135国产精品免费| 欧美在线视频网站| 3d成人动漫在线| 亚洲国产黄色片| 日韩视频在线观看视频| 制服丝袜中文字幕在线| 日韩精品999| 亚洲手机在线观看| 精品久久久久久久久久| 99自拍偷拍视频| 高清在线不卡av| 国产淫片av片久久久久久| 色小子综合网| 国内外成人免费视频| 99综合久久| 美女av一区二区| 男人天堂网在线观看| 91精品在线免费观看| 精品91久久久| 综合分类小说区另类春色亚洲小说欧美 | 欧美性猛片aaaaaaa做受| 日韩av毛片在线观看| 91亚洲精品乱码久久久久久蜜桃| 岛国毛片在线播放| 亚洲欧美成人| 激情六月天婷婷| 欧美码中文字幕在线| 91亚洲人电影| 久久精品超碰| 青草热久免费精品视频| 黄色免费在线看| 亚洲日本中文字幕| www精品国产| 欧美日本在线观看| 伊人网综合在线| 懂色aⅴ精品一区二区三区蜜月| 日本在线一级片| 国产午夜亚洲精品不卡| 国产伦精品一区三区精东| 日韩精品福利网| 久草青青在线观看| 亚洲精品欧洲| 91免费国产精品| 外国成人激情视频| 亚洲日本无吗高清不卡| 欧美理伦片在线播放| 成人黄动漫网站免费| 91成人精品观看| 国产欧美日韩高清| 欧洲av一区二区| 青草热久免费精品视频| 色av手机在线| 欧美激情一区二区久久久| 成人福利片网站| 俺去了亚洲欧美日韩| 91美女视频在线| 在线免费看av不卡| 日本三级在线视频| 日韩有码视频在线| 日本免费中文字幕在线| 中文字幕九色91在线| 国产在线一二三区| 怡红院精品视频| jizzjizz在线观看| 尤物九九久久国产精品的特点| 可以在线观看的黄色| 亚洲视频自拍偷拍| av片在线免费观看| 最新的欧美黄色| 久做在线视频免费观看| 久久躁狠狠躁夜夜爽| 一区二区三区伦理| 91精品国产色综合久久不卡98| 成人一级福利| 欧美诱惑福利视频| av在线日韩| 国产精自产拍久久久久久蜜| 99久久999| 国产精品一区二区三区不卡 | 日韩视频不卡中文| 亚洲精品一区二区三区区别| 日韩精品免费在线视频| 九一在线视频| 在线日韩av观看| 免费网站黄在线观看| 欧美日韩爱爱视频| 韩漫成人漫画| 国产自产女人91一区在线观看| 97久久精品一区二区三区的观看方式| 97久久夜色精品国产九色 | 久久91精品国产91久久小草 | 波多野结衣电车| 欧美日韩1区2区| 成人午夜视频一区二区播放| 日韩精品在线免费观看| 国产三级在线看| 久久久免费观看视频| jizz内谢中国亚洲jizz| 国产欧美 在线欧美| 澳门精品久久国产| 日韩经典在线视频| 亚洲一级网站| 少妇一级淫免费放| 国产成人av电影| 欧洲女同同性吃奶| 亚洲美女精品一区| 69国产精品视频免费观看| 欧美高清视频一二三区| 天天操天天干天天| 欧美日韩国产二区| 色尼玛亚洲综合影院| 3d动漫精品啪啪一区二区三区免费| 日韩极品少妇| 丝袜美腿玉足3d专区一区| 精品福利电影| 亚洲国产高清av| 成人动漫在线一区| 亚洲怡红院在线观看| 91久久国产最好的精华液| 亚洲国产av一区二区| 宅男66日本亚洲欧美视频| 欧美xxxx少妇| 国产精品稀缺呦系列在线| 亚洲性视频大全| 亚洲精品蜜桃久久久久久| 久久精品久久精品| 中文字幕在线免费看线人| 亚洲黄色小视频| 伊人成人在线观看| 精品在线小视频| 黄色污污视频在线观看| 国产欧美日韩高清| 日韩系列欧美系列| 日本精品免费在线观看| 丁香六月久久综合狠狠色| 中文字幕观看av| 日韩欧美精品在线观看| 囯产精品一品二区三区| 在线亚洲国产精品网| 国产经典三级在线| caoporn国产精品免费公开| 97视频精品| 三级视频中文字幕| 久久久久国产免费免费| 最新中文字幕一区| 亚洲国产精品电影| 不卡av免费观看| caoporn国产精品免费公开| 欧美日韩国产欧| 亚洲 自拍 另类 欧美 丝袜| 亚洲欧美日韩综合aⅴ视频| 一区二区三区播放| 亚洲网站在线播放| xxxxx性欧美特大| 久久av一区二区三区亚洲| 日本丰满少妇做爰爽爽| 日韩av网站在线| 超碰在线公开| 精品国产一区二区三区免费| 激情视频一区| 无码国产精品一区二区高潮| 亚洲日本va午夜在线影院| 97在线播放免费观看| 久久精品男人天堂| 六九午夜精品视频| 一区二区精品在线| 精品在线一区二区三区| 五月婷婷综合激情网| 欧美色图免费看| 成人在线网址| 超碰97人人人人人蜜桃| 在线精品一区二区| 91人妻一区二区| 欧美日韩中文字幕在线视频| 青青色在线视频| 日本精品视频在线观看| 五月激激激综合网色播| 91n.com在线观看| 国产精品久久久99| 国产aⅴ爽av久久久久成人| 美女精品视频一区| 久久精品论坛| 成人免费毛片播放| 中文字幕欧美三区| av片免费观看| 久久久国产成人精品| 亚洲精品一区二区三区中文字幕| 精品少妇人欧美激情在线观看| 成人影院在线看| 亚洲在线第一页| 伊人成人在线| 日本黄色录像片| 欧美三级日韩在线| 欧美性爽视频| 免费成人在线观看av| 精彩视频一区二区三区| 欧美三级免费看| 亚洲乱码av中文一区二区| 日韩一区二区三区四区五区 | 日本高清不卡视频| 久草中文在线|