成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

iOS開發3年只用5分鐘搞定面試官

移動開發 iOS
假輿馬者,非利足也,而致千里;假舟楫者,非能水也,而絕江河。君子生非異也,善假于物也。我們曾借白茶清歡等一個人,曾借花開花落嘆寵辱不驚。程序(Program)是一個可以運行的文件, 一個程序至少有一個進程,一個進程至少有一個線程,即主線程

序言

假輿馬者,非利足也,而致千里;假舟楫者,非能水也,而絕江河。君子生非異也,善假于物也。

我們曾借白茶清歡等一個人,曾借花開花落嘆寵辱不驚。

程序(Program)是一個可以運行的文件, 一個程序至少有一個進程,一個進程至少有一個線程,即主線程

正文

  • 程序(Program)是一個可以運行的文件, 一個程序至少有一個進程,一個進程至少有一個線程,即主線程
  • 進程:正在進行的程序被稱為進程,負責程序運行的內存分配,每個進程都有自己的獨立虛擬內存空間.一個程序的一次運行,在執行過程中擁有獨立的內存單元,而多個線程共享一塊內存
  • 什么是線程:線程是進程中的基本單元(可執行的代碼段),線程可以并發運行,提高執行效率
  • 創建線程的目的:就是為了開啟一條新的可執行的代碼段,與主線程中的代碼實現同時運行,防止界面假死,是實現異步的技術的主要手段,比如網絡異步下載

一 Runloop知識點補充

1 在模擬器中拖拽UITextView的時候對RunLoop模式的影響

1.1 performSelector: 方法

—-對該方法的解釋: 該方法運行的時候回受到runloop運行模式的影響,默認設置為defaulmode,當拖拽的時候,runloop切換模式,所以不執行

代碼塊和解釋一:

 

  1. //由于該方法設置了RunLoop的運行模式為兩種,當用戶滑動UITextView的時候RunLoop切換模式并且繼續執行,所以能設置出圖片 
  2.     [self.imageView1 performSelector:@selector(setImage:) withObject:[UIImage imageNamed:@"/Users/xiaofeng/Desktop/Snip20160319_18.png"] afterDelay:5.0 inModes:@[UITrackingRunLoopMode,NSDefaultRunLoopMode]]; 

代碼塊和解釋二:

 

  1. //該方法的執行會受到外界的影響,當用戶滑動UITextView的時候,并不會經過2秒設置圖片,runloop運行的模式是默認的模式,當用戶滑動UITextView的時候,切換了模式,所以不會設置圖片 
  2.     [self.imageView1 performSelector:@selector(setImage:) withObject:[UIImage imageNamed:@"/Users/xiaofeng/Desktop/Snip20160319_15.png"] afterDelay:2.0]; 

2 問題:怎么能讓一個線程一直活著,然后在特定的情況下,讓線程跳轉任務

二 常駐線程

3 保證線程不死的方法:創建一個RunLoop循環;然后設置數據源或者定時器

  • 3.1 ***種方法:開啟一個死循環—>比如while死循環,保持線程不死亡,這樣雖然能保證線程不死,但是不能保證線程去執行其它的任務(不可取)
  • 3.2 第二種方法:開啟一個RunLoop循環,也可以保證讓線程不死,但是開啟了需要手動執行,并且需要設置運行模式,否則單單只是開啟了RunLoop循環,并沒有設置模式的話,RunLoop開啟了就直接退出,并不會一直往下執行(開啟RunLoop需要完成指定的三個步驟)

4 需求:當點擊創建線程的按鈕的時候,開始創建一條線程,然后點擊讓子線程開始干其他的工作的時候,子線程開始執行其他工作

1 創建子線程按鈕:

 

  1. #pragma mark - 創建子線程按鈕 
  2. - (IBAction)creatBtnClick:(id)sender 
  3.     //創建子線程 
  4.     NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(task) object:nil]; 
  5.       
  6.     [thread start]; 
  7.     //如果不加入這句代碼,線程在執行完task方法之后就會立刻被釋放,這里寫這句代碼目的就是保證線程不死,能繼續執行其他的任務 
  8.     self.thread = thread; 

創建子線程按鈕中的方法實現: 在task方法中我們只要求打印當前線程就行.

讓子線程開始繼續工作:

 

  1. #pragma mark - 讓線程繼續工作 
  2.   
  3. - (IBAction)goOnBtnClick:(id)sender 
  4.     [self performSelector:@selector(task2) onThread:self.thread withObject:nil waitUntilDone:YES]; 

問題:如果就這樣運行的話,就會報錯.

報錯原因:雖然上面在創建子線程中已經寫了一句self.thread = thread保證子線程不會被釋放,但是由于沒有開啟runloop循環,那么子線程其實是處于死亡狀態,所以當在點擊讓子線程繼續工作的話就會報錯.

解決辦法:創建子線程的RunLoop,讓子線程一直在運行,然后通過設置在方法里面的調用其它的需要子線程工作的方法,讓子線程去工作

 

  1. #pragma mark - 工作在線程中的任務 
  2. - (void)task 
  3.     NSLog(@"1------%@",[NSThread currentThread]); 
  4.     //創建RunLoop 
  5.     NSRunLoop *runLoop = [NSRunLoop currentRunLoop]; 
  6.    
  7.     //創建timer(這種方法需要手動設置模式) 
  8.     NSTimer *timer = [NSTimer timerWithTimeInterval:2.0 target:self selector:@selector(timeRun) userInfo:nil repeats:YES]; 
  9. // 
  10. //    //添加到runloop中,并設置模式 
  11.     [runLoop addTimer:timer forMode:NSDefaultRunLoopMode]; 
  12. //    [runLoop addPort:[NSPort port] forMode:NSDefaultRunLoopMode]; 
  13.   
  14.     //開啟runloop 
  15.   
  16.     [runLoop run]; 
  17.     NSLog(@"%s-------2-----%@",__func__,[NSThread currentThread]); 

注意:上面創建時鐘的代碼和添加時鐘到runloop中的代碼可以寫成下面一句,同樣也能保證線程不處于死亡狀態

  1. [runLoop addPort:[NSPort port] forMode:NSDefaultRunLoopMode]; 

5 RunLoop的自動釋放池

  • ***次創建 RunLoop啟動的時候
  • ***一次 RunLoop退出的時候
  • 其它時間的創建和銷毀:當RunLoop即將休眠的時候會把之前的自動釋放池銷毀,重新創建一個新的

6 RunLoop在網絡中的應用(直接看代碼就可以)

 

  1. - (void)delegate1 
  2.     //確定請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  4.     //創建可變的請求對象 
  5.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; 
  6.     //設置代理 
  7.     NSURLConnection *connention = [[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES]; 
  8.   
  9.     //加入該段代碼可以改變代理方法執行的線程,默認是在主線程中執行,但是加入該段代碼之后,代理方法會在子線程中執行 
  10.     [connention setDelegateQueue:[[NSOperationQueue alloc] init]]; 
  11.   
  12.     //開始發送請求 
  13.     //1)該方法內部會吧connention對象作為一個source添加到runloop中,并且制定運行模式為默認 
  14.     //2)如果發現當前的runloop不存在,那么該方法內部會自動的創建并開啟當前子線程的runloop 
  15.     [connention start]; 

三 網絡

1 GET和POST對比:

  • GET請求參數直接跟在URL后面(?)
  • POST請求參數是在請求體里面

2 HTTP基本通信過程:客戶端—>請求—->服務器;服務器—>響應—->客戶端

 

  1. 具體的操作步驟: 
  2. 2.1 確定請求路徑 
  3. 2.2 獲取主機名 
  4. 2.3 DNS域名解析 
  5. 2.4 獲得端口號 
  6. 2.5 鏈接到120.25.226.186的端口80 
  7. 2.6 發送一個HTTP GET請求 
  8. 2.7 接收服務器的響應 
  9. 2.8 關閉鏈接 

3 請求和響應

請求:

  • 請求頭:包含了客戶端的環境描述,客戶端請求信息等
  • 請求體:客戶端發給服務器的具體數據,比如文件數據(POST請求才會有)

響應:

  • 響應頭:包含了對服務器的描述,對返回數據的描述
  • 響應體:服務器返回給客戶端的具體數據,比如文件數據

如圖:

 

4 HTTP請求

HTTP請求的第三方框架:ASIHttpRequest(已經棄用);AFNetworking(主用);MKNetworking

蘋果自帶的:

  • NSURLConnection:用法簡單,最古老最經典最直接的一種方案
  • NSURLSession:功能比NSURLConnection更強大,蘋果目前比較推薦的使用技術(重要)
  • CFNetwork:NSURL*的底層,純C語言

第三方框架:(企業開發基本使用的是第三方框架)

  • ASIHttpRequest:外號”HTTP終結者”,功能極其強大,可惜已經停止更新了
  • AFNetworking:簡單易用,提供了基本夠用的常用功能,維護和使用者多(重要)
  • MKNsetworking:簡單易用,產生三哥的故鄉印度,維護和使用者少

四 GET方式

  • 概念:發送網絡請求的兩種方式,主要區別上面已經有寫
  • 發送同步請求

具體步驟:

 

  1. 1> 確定請求路徑 
  2. 2> 創建請求對象 
  3. 3> 發送請求 
  4. 4 > 解析接收數據 

 

  1. #pragma mark - 發送同步請求 
  2. - (void)sendSync 
  3.     //確定請求路徑 
  4.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  5.   
  6.     //創建請求對象 
  7.     NSURLRequest *request = [NSURLRequest requestWithURL:url]; 
  8.   
  9.     //初始化響應頭信息(設置為空) 
  10.     NSHTTPURLResponse *response = nil; 
  11.     //初始化錯誤信息 
  12.     NSError *error = nil; 
  13.   
  14.     //發送請求 
  15.     /** 
  16.      *  ***個參數:請求對象 
  17.      * 
  18.      *  第二個參數:響應頭信息(傳入的是地址) 
  19.      * 
  20.      *  第三個參數:錯誤信息(如果發送請求失敗,那么error就有值)(傳入的是地址) 
  21.      */ 
  22.     NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error]; 
  23.   
  24.     //解析返回的響應數據 
  25.     NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 

3 發送異步請求

注意:同步請求和異步請求的主要區別就是發送請求中的方法不同.

 

  1. #pragma mark - 發送異步請求 
  2.   
  3. - (void)sendAsync 
  4.     //確定請求路徑 
  5.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  6.   
  7.     //創建請求對象 
  8.     NSURLRequest *resquest = [NSURLRequest requestWithURL:url]; 
  9.   
  10.     //發送請求 
  11.     /** 
  12.      *  參數一:請求對象 
  13.      * 
  14.      *  參數二:隊列(作用在completionHandler上面) 
  15.      * 
  16.      *  參數三:響應的信息(響應頭;響應的數據) 
  17.                 response 響應頭信息 
  18.                 data     響應體信息 
  19.                 connectionError 錯誤信息 
  20.      */ 
  21.     [NSURLConnection sendAsynchronousRequest:resquest queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) { 
  22.         //解析數據 
  23.         NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  24.     }]; 

4 用代理的方法發送網絡請求

注意:需要遵守協議:

  1. <nsurlconnectiondatadelegate></nsurlconnectiondatadelegate> 

代理方法發送,里面包括了設置代理的三種方式

 

  1. #pragma mark - 代理方法發送請求 
  2. - (void)sendAsyncDelegate 
  3.     //確定請求路徑 
  4.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  5.   
  6.     //創建請求對象 
  7.     NSURLRequest *request = [NSURLRequest requestWithURL:url]; 
  8.   
  9.     //設置代理 
  10.     //***種設置代理: 
  11.     [NSURLConnection connectionWithRequest:request delegate:self]; 
  12.     //第二種設置代理: 
  13.     NSURLConnection *connecttion1 = [[NSURLConnection alloc] initWithRequest:request delegate:self]; 
  14.     //第三種設置代理: 
  15.     NSURLConnection *connecttion2 = [[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES]; 
  16.   
  17.     [connecttion2 start];   

實現代理中的方法

 

  1. #pragma mark - 代理方法 
  2. //請求失敗的時候調用 
  3. - (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error 
  4.     NSLog(@"%s------%@",__func__,[NSThread currentThread]); 
  5. //接收響應頭信息 
  6. - (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response 
  7.     NSLog(@"%s------%@",__func__,[NSThread currentThread]); 
  8.   
  9.     //創建接收可變的二進制數據 
  10.     self.responseData = [NSMutableData data]; 
  11.   
  12. //接收響應體(如果數據足夠大那么這個方法會調用多次) 
  13. - (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data 
  14.     NSLog(@"%s------%@",__func__,[NSThread currentThread]); 
  15.     //拼接二進制數據 
  16.     [self.responseData appendData:data]; 
  17.   
  18. //接收完成(不管成功還是失敗) 
  19. - (void)connectionDidFinishLoading:(NSURLConnection *)connection 
  20.     NSLog(@"%s------%@",__func__,[NSThread currentThread]); 
  21.   
  22.     //解析數據 
  23.     NSLog(@"%@",[[NSString alloc] initWithData:self.responseData encoding:NSUTF8StringEncoding]); 

五 POST方式

1 直接看代碼,上面都標明了

 

  1. - (void)touchesBegan:(NSSet*)touches withEvent:(UIEvent *)event 
  2.     //創建請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login"]; 
  4.     //創建可變的請求對象 
  5.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; 
  6.   
  7.     //修改請求方式 
  8.     request.HTTPMethod = @"POST"
  9.   
  10.     //設置請求超時 
  11.     request.timeoutInterval = 10; 
  12.   
  13.     NSURLResponse *response = nil; 
  14.   
  15.     NSError *error = nil; 
  16.   
  17.     //設置請求頭信息 
  18.     [request setValue:@"jjjj" forHTTPHeaderField:@"uuuuu"]; 
  19.   
  20.     //設置請求體(參數) 
  21.     request.HTTPBody = [@"username=520it&pwd=520it&type=JSON" dataUsingEncoding:NSUTF8StringEncoding]; 
  22.   
  23.     //***種方法:發送請求(異步請求) 
  24.     [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) { 
  25.         //解析數據 
  26.         if (connectionError == nil) { 
  27.             NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  28.   
  29.         }else
  30.             NSLog(@"%@",connectionError); 
  31.         } 
  32.     }]; 
  33.   
  34.     //第二種方法:發送請求(同步請求) 
  35.     NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error]; 
  36.     //解析數據 
  37.     NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 

六 中文轉碼

  1. 判斷需不需要轉碼操作:看請求路徑是否含有中文,含有的話,就需要轉碼
  2. 設置代理的多一個參數的方法中:如果設置的為NO,那么手動開啟的時候,底層start會把線程加入到runloop中,但是如果設置的為yes,那么和沒有參數的時候一樣,需要手動創建runloop.

GET轉碼:

 

  1. #pragma mark - GET轉碼 
  2. - (void)get 
  3.     //確定請求字符串 
  4.     NSString *strurl = @"http://120.25.226.186:32812/login2?username=(需要轉的漢字)&pwd=520it&type=JSON"
  5.   
  6.     //轉碼 
  7.     strurl = [strurl stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding]; 
  8.   
  9.     //確定路徑 
  10.     NSURL *url = [NSURL URLWithString:strurl]; 
  11.   
  12.     //創建可變的請求對象 
  13.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; 
  14.   
  15.     //發送請求--->GET請求 
  16.     [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) { 
  17.        //解析數據 
  18.         if (connectionError == nil) { 
  19.             NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  20.         }else
  21.             NSLog(@"%@",connectionError); 
  22.         } 
  23.     }]; 

POST轉碼:

 

  1. #pragma mark - POST轉碼 
  2. - (void)post 
  3.     //確定請求路徑的字符串 
  4.     NSString *urlstr = @"http://120.25.226.186:32812/login2"
  5.   
  6.     //確定url 
  7.     NSURL *url = [NSURL URLWithString:urlstr]; 
  8.   
  9.     //創建請求對象 
  10.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; 
  11.   
  12.     //轉為POST格式 
  13.     request.HTTPMethod = @"POST"
  14.     //轉碼 
  15.     request.HTTPBody = [@"username=(需要轉的漢字)&pwd=520it&type=JSON" dataUsingEncoding:NSUTF8StringEncoding ]; 
  16.     NSURLResponse *response = nil; 
  17.     NSError *error = nil; 
  18.   
  19.     //發送請求(同步請求) 
  20.     NSData *data = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error]; 
  21.     //解析數據 
  22.     NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  23.   
  24.     //發送請求(異步請求) 
  25.     [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) { 
  26.         //解析數據 
  27.         if (connectionError == nil) { 
  28.             NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  29.         }else
  30.             NSLog(@"%@",connectionError); 
  31.         } 
  32.   
  33.     }];     

七 NSURLSession簡單使用

1 NSURLSession —->GET用法:

 

  1. - (void)get 
  2.     //確定請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  4.     //創建請求對象 
  5.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url ]; 
  6.     //獲取會話對象(是一個單例) 
  7.     NSURLSession *session = [NSURLSession sharedSession]; 
  8.   
  9.     //根據會話對象創建task 
  10.     /** 
  11.      *  參數一:請求對象 
  12.      * 
  13.      *  參數二:響應頭response信息;響應體data信息;error錯誤信息 
  14.      * 
  15.      * 
  16.      */ 
  17.     NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) { 
  18.         //解析數據 
  19.         NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  20.         //該block塊是在子線程中調用 
  21.          NSLog(@"%@",[NSThread currentThread]); 
  22.     } ]; 
  23.   
  24.     //執行task 
  25.     [dataTask resume]; 

2 GET用法二:

 

  1. - (void)get1 
  2.     //確定請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  4.   
  5.     //創建請求對象 
  6. //    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url]; 
  7.   
  8.     //創建會話對象 
  9.     NSURLSession *session = [NSURLSession sharedSession]; 
  10.   
  11.     //根據會話對象創建task 
  12.     NSURLSessionDataTask *dataTask = [session dataTaskWithURL:url completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) { 
  13.         NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  14.         //該block塊是在子線程中調用 
  15.          NSLog(@"%@",[NSThread currentThread]); 
  16.     }]; 
  17.     //開啟task 
  18.     [dataTask resume]; 

3 GET1和GET2的區別是根據會話對象創建task不同,其實用法還是一樣的.

4 POST用法:

 

  1. - (void)post 
  2.     //確定請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login"]; 
  4.   
  5.     //創建可變的請求對象 
  6.     NSMutableURLRequest *resquest = [NSMutableURLRequest requestWithURL:url]; 
  7.   
  8.     //轉換格式 
  9.     resquest.HTTPMethod = @"POST"
  10.   
  11.     //設置請求體信息 
  12.     resquest.HTTPBody = [@"username=520it&pwd=520it&type=JSON" dataUsingEncoding:NSUTF8StringEncoding]; 
  13.   
  14.     //獲取會話 
  15.     NSURLSession *session = [NSURLSession sharedSession]; 
  16.   
  17.     //用會話對象創建task 
  18.     NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:resquest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) { 
  19.   
  20.         //解析數據 
  21.         if (error == nil) { 
  22.             NSLog(@"%@",[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]); 
  23.         }else
  24.             NSLog(@"%@",error); 
  25.         } 
  26.         //該block塊是在子線程中調用 
  27.         NSLog(@"%@",[NSThread currentThread]); 
  28.     }]; 
  29.   
  30.     //執行task任務   resume------>恢復 
  31.     [dataTask resume]; 

八 NSURLSession的代理方法

1 主方法(在里面設置代理)

 

  1. - (void)sessionGet 
  2.     //確定請求路徑 
  3.     NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
  4.     //創建可變的請求對象 
  5.     NSURLRequest *request = [NSURLRequest requestWithURL:url]; 
  6.   
  7.     //獲取會話(delegateQueue:決定了代理的任務是在子線程還是主線程中執行的) 
  8.     NSURLSession *session = [NSURLSession sessionWithConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration] delegate:self delegateQueue:[NSOperationQueue mainQueue]]; 
  9.   
  10.     //創建task 
  11.     NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:request]; 
  12.     //執行task任務 
  13.     [dataTask resume]; 
  14.   

2 代理方法

注意: 此代理方法要特別的注意***個代理方法,因為需要回調告訴系統怎么樣處理服務器返回的數據,如果沒有寫的話,后面兩個代理方法是不會調用的,因為completionHandler并沒有告訴系統,服務器的數據怎么處理.

 

  1. #pragma mark - 代理方法 
  2. //接收響應 
  3. - (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveResponse:(NSURLResponse *)response completionHandler:(void (^)(NSURLSessionResponseDisposition))completionHandler 
  4.     NSLog(@"%s-------%@",__func__,[NSThread currentThread]); 
  5.   
  6.     self.data = [NSMutableData data]; 
  7.     //在該方法中需要通過completionHandler回調告訴系統應該如何處理服務器返回的數據 
  8.     completionHandler(NSURLSessionResponseAllow); 
  9. //接收到二進制數據(如果數據量大會調用多次) 
  10. - (void)URLSession:(NSURLSession *)session dataTask:(NSURLSessionDataTask *)dataTask didReceiveData:(NSData *)data 
  11.   
  12.     NSLog(@"%s-----%@",__func__,[NSThread currentThread]); 
  13.     //拼接數據 
  14.     [self.data appendData:data]; 
  15.   
  16. //完成或者失敗的時候調用 
  17. - (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didCompleteWithError:(NSError *)error 
  18.     NSLog(@"%s------%@",__func__,[[NSString alloc] initWithData:self.data encoding:NSUTF8StringEncoding]); 
  19.     NSLog(@"%@",[NSThread currentThread]); 

 

責任編輯:未麗燕 來源: 簡書
相關推薦

2010-03-05 17:28:08

2009-11-26 11:19:52

NIS服務器

2011-05-26 09:03:17

JSONjavascript

2016-04-06 11:14:48

iOS相機自定義

2020-12-18 07:33:20

SpringSchedule組件

2012-06-28 10:26:51

Silverlight

2013-06-24 15:32:41

JPush極光推送Android Pus移動開發

2020-09-14 11:30:26

HTTP3運維互聯網

2010-11-03 11:01:05

求職面試

2021-12-10 06:52:24

業務

2021-04-30 16:23:58

WebRTC實時音頻

2021-12-01 06:50:50

Docker底層原理

2020-10-27 10:43:24

Redis字符串數據庫

2014-04-15 11:19:19

2011-07-11 09:58:52

2020-12-09 06:19:39

ReLU神經網絡深度學習

2020-07-25 19:40:33

Java開發代碼

2015-04-21 17:35:29

代碼

2025-03-18 09:20:00

Go語言Golang

2021-12-02 06:58:03

AIOps通信服務
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www日韩高清 | 日本一区二区不卡 | 最近日韩中文字幕 | 亚洲一区二区三区在线播放 | 久久国产精彩视频 | 黄色网页在线 | 日韩精品一区二区三区中文字幕 | 香蕉久久网 | 国产中文字幕网 | 国产免国产免费 | 久久综合一区二区 | 综合精品| 欧美在线视频a | 精品国产鲁一鲁一区二区张丽 | www.日韩| 免费国产一区二区 | 日本精a在线观看 | 亚洲精品免费观看 | 日韩中文字幕视频在线观看 | 九九综合九九 | 视频二区国产 | 日本不卡免费新一二三区 | 国产99久久| 亚洲成人久久久 | 久久综合入口 | 一区二区三区视频在线观看 | 老外黄色一级片 | 国产成人福利视频 | 国产精品久久久亚洲 | 国产精品久久久久久久久久三级 | 草久网| a级大片免费观看 | 久久精品免费一区二区三 | 欧美日韩三区 | 久在线观看 | 天天操综合网站 | 免费在线观看一区二区三区 | 日韩毛片在线视频 | 日本精品在线一区 | 国产三级| 九九九视频在线 |