[Xcode 實際操做]8、網絡與多線程-(10)使用異步Get方式查詢GitHub數據

 目錄:[Swift]Xcode實際操做html

本文將演示如何經過Get請求方式,異步獲取GitHub資源的詳細信息。ios

異步請求與同步請求相比,不會阻塞程序的主線程,而會創建一個新的線程。git

在項目導航區,打開視圖控制器的代碼文件【ViewController.swift】github

 1 import UIKit
 2 
 3 class ViewController: UIViewController {
 4     
 5     //給當前視圖控制器類,添加一個標籤屬性。
 6     //該標籤對象,將用來顯示遠程服務器返回的信息
 7     var label = UILabel()
 8     
 9     override func viewDidLoad() {
10         super.viewDidLoad()
11         // Do any additional setup after loading the view, typically from a nib.
12         
13         //設置標籤對象的位置在(20,40),尺寸爲(280,500)
14         label.frame = CGRect(x: 20, y: 40, width: 280, height: 500)
15         //設置標籤對象的文字內容
16         label.text = "Loading..."
17         //設置標籤對象的字體和大小
18         label.font = UIFont(name: "Arial", size: 12)
19         //設置標籤對象的背景顏色爲淺灰色
20         label.backgroundColor = UIColor.lightGray
21         //設置標籤對象的行數屬性值爲0,表示不限制標籤對象的行數
22         label.numberOfLines = 0
23         //遠程服務器有可能返回較多的文字內容,
24         //在此設置標籤對象在進行換行時,保留全部的字符
25         label.lineBreakMode = NSLineBreakMode.byWordWrapping
26         //將設置好的標籤對象,添加到當前視圖控制器的根視圖
27         self.view.addSubview(label)
28         
29         //建立一個網址對象,指定請求網絡數據的網址。
30         let url = URL(string: "https://api.github.com/repos/tulios/json-viewer")
31         
32         //建立一個網絡請求對象,參數說明:
33         //1.表明請求訪問的路徑
34         //2.表明網絡請求的緩存協議
35         //3.表明網絡請求的超時時間
36         let request = URLRequest.init(url: url!,
37         cachePolicy: .useProtocolCachePolicy,
38         timeoutInterval: 30)
39         
40         //網址會話URLSession在2013年發佈,蘋果對它的定位是做爲舊的網絡請求接口的替代者。
41         //這裏得到網址會話的單例對象
42         let session = URLSession.shared
43         //全部網絡請求工做,都是經過網址會話任務對象來完成的。
44         //能夠使用閉包、代理或者二者混合的方式,來建立網絡請求任務。
45         //建立一個網絡請求任務,根據指定的網址請求對象,獲取接口的內容,
46         //並在完成時經過閉包語句,處理服務器返回的數據
47         let task = session.dataTask(with: request, completionHandler: {(data, response, error) -> Void in
48             //若是出現網絡請求錯誤,
49             if error != nil{
50                 //則在控制檯打印輸出錯誤代碼和錯誤信息
51                 print(error.debugDescription)
52             }else{
53                 //將網絡返回的數據對象,根據指定的編碼方式,轉換爲字符串
54                 let result = String(data: data!, encoding: String.Encoding.utf8)
55                 //當在一個線程中,須要更改界面元素時,須要返回程序的主線程
56                 DispatchQueue.main.async(execute: { () -> Void in
57                     //更新標籤對象的文字內容
58                     self.label.text = result! as String
59                 })
60             }
61         })
62         
63         //任務建立後,調用resume方法開始工做。
64         task.resume()        
65     }
66     
67     override func didReceiveMemoryWarning() {
68         super.didReceiveMemoryWarning()
69         // Dispose of any resources that can be recreated.
70     }
71 }
相關文章
相關標籤/搜索