iOS網絡編程之同步、異步、請求隊…

摘自:http://mobile.51cto.com/iphone-321183.htm

1. 同步意爲着線程阻塞,在主線程中使用此方法會不響應任何用戶事件。所以,在應用程序設計時,大多被用在專門的子線程增加用戶體驗,或用異步請求代替。


  1. - (IBAction)grabURL:(id)sender  
  2. {  
  3. NSURL *url = [NSURL URLWithString:@"http://allseeing-i.com"];  
  4. ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];  
  5. [request startSynchronous];  
  6. NSError *error = [request error];  
  7. if (!error) {  
  8. NSString *response = [request responseString];  
  9. }  

用 requestWithURL 快捷方法獲取 ASIHTTPRequest 的一個實例

startSynchronous 方法啓動同步訪問

由於是同步請求,沒有基於事件的回調方法,所以從 request的error 屬性獲取錯誤信息

responseString,爲請求的返回 NSString 信息 *

注意:在這裏我發現NsUrlRequset和connect系統Api就可以配合做到效果。也不需要到移植開源代碼

2. 異步請求的好處是不阻塞當前線程,但相對於同步請求略爲複雜,至少要添加兩個回調方法來獲取異步事件


  1. - (IBAction)grabURLInBackground:(id)sender  
  2. {  
  3. NSURL *url = [NSURL URLWithString:@"http://allseeing-i.com"];  
  4. ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];  
  5. [request setDelegate:self];  
  6. [request startAsynchronous];  
  7. }  
  8.  
  9. - (void)requestFinished:(ASIHTTPRequest *)request  
  10. {  
  11. // Use when fetching text data  
  12. NSString *responseString = [request responseString];  
  13.  
  14. // Use when fetching binary data  
  15. NSData *responseData = [request responseData];  
  16. }  
  17.  
  18. - (void)requestFailed:(ASIHTTPRequest *)request  
  19. {  
  20. NSError *error = [request error];  

與上面不同的地方是指定了一個 “delegate”,並用 startAsynchronous 來啓動網絡請求

在這裏實現了兩個 delegate 的方法,當數據請求成功時會調用 requestFinished,請求失敗時(如網絡問題或服務器內部錯誤)會調用 requestFailed。

PS: 異步請求一般來說更常用一些,而且裏面封裝都挺不錯的,至少比symbian等平臺方便的多,而且還可以修改源代碼。多數這個跟隊列混合封裝來達到圖片和異步下載包的目的(已實現)。

3. 請求隊列提供了一個對異步請求更加精準豐富的控制。如:可以設置在隊列中同步請求的連接數。往隊列裏添加的請求實例數大於 maxConcurrentOperationCount 時,請求實例將被置爲等待,直到前面至少有一個請求完成並出列才被放到隊列裏執行。這也適用於當我們有多個請求需求按順序執行的時候(可能是業務上的需要,也可能是軟件上的調優),僅僅需要把 maxConcurrentOperationCount 設爲“1”。


  1. - (IBAction)grabURLInTheBackground:(id)sender  
  2. {  
  3. if (![self queue]) {  
  4. [self setQueue:[[[NSOperationQueue alloc] init] autorelease]];  
  5. }  
  6.  
  7. NSURL *url = [NSURL URLWithString:@"http://allseeing-i.com"];  
  8. ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];  
  9. [request setDelegate:self];  
  10. [request setDidFinishSelector:@selector(requestDone:)];  
  11. [request setDidFailSelector:@selector(requestWentWrong:)];  
  12. [[self queue] addOperation:request]; //queue is an NSOperationQueue  
  13. }  
  14.  
  15. - (void)requestDone:(ASIHTTPRequest *)request  
  16. {  
  17. NSString *response = [request responseString];  
  18. }  
  19.  
  20. - (void)requestWentWrong:(ASIHTTPRequest *)request  
  21. {  
  22. NSError *error = [request error];  

創建 NSOperationQueue,這個 Cocoa 架構的執行任務(NSOperation)的任務隊列。我們通過 ASIHTTPRequest.h 的源碼可以看到,此類本身就是一個 NSOperation 的子類。也就是說它可以直接被放到”任務隊列”中並被執行

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章