我无法理解为什么我的数组(amountArray,interestArray和riskbandArray)返回完整的信息集,如果我在forloop之后打印它们,而如果我在viewDidload方法的末尾打印它们则不返回任何内容。我知道它可能是因为网络请求正在后台执行,所以当我要求打印我的数组时,没有返回任何内容,因为它是在主线程中调用的。我试图通过引入Grand Central Dispatch来抵消这一点,但我的阵列仍然是空的。太令人沮丧了。
class CollectionViewController: UICollectionViewController {
var amountArray = [Int]()
var interestArray = [Double]()
var riskbandArray = [String]()
override func viewDidLoad() {
super.viewDidLoad()
let session = NSURLSession.sharedSession()
let Url = NSURL(string: "http://fc-ios-test.herokuapp.com/auctions")
let task: NSURLSessionDownloadTask = session.downloadTaskWithURL(Url!) { (url, response, error) -> Void in
dispatch_async(dispatch_get_main_queue(), { () -> Void in
let data = NSData(contentsOfURL: url!)
do {
let jsonData = try NSJSONSerialization.JSONObjectWithData(data!, options:NSJSONReadingOptions.MutableContainers) as! NSDictionary
if let array = jsonData["items"] as? [[NSObject:AnyObject]] {
for item in array {
self.amountArray.append(item["amount_cents"] as! Int)
self.interestArray.append(item["rate"] as! Double * 100)
self.riskbandArray.append(item["risk_band"] as! String)
}
}
self.collectionView?.reloadData()
} catch {
print(error)
}
})
}
task.resume()
// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false
// Register cell classes
self.collectionView!.registerClass(UICollectionViewCell.self, forCellWithReuseIdentifier: reuseIdentifier)
// Do any additional setup after loading the view.
print(self.amountArray)
}
答案 0 :(得分:0)
这是一个显示代码相关部分的简化版本:
let task: NSURLSessionDownloadTask = session.downloadTaskWithURL(Url!) {...}
task.resume()
print(self.amountArray)
所以你要创建一个任务并启动它,然后立即打印amountArray
。重要的是要知道任务将异步运行,即它将定期获得处理时间直到完成,但是在任务真正开始之前,代码的执行将从task.resume()
继续。因此,print()
在将数据添加到amountArray
的代码发生之前很久就会执行。
如果你想查看self.amountArray
中的内容,请移动print()
语句,使其成为任务完成块中发生的最后一件事。然后在更改数组后发生。