我不明白为什么我的数组(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)
}
最佳答案
这是显示代码相关部分的精简版:
let task: NSURLSessionDownloadTask = session.downloadTaskWithURL(Url!) {...}
task.resume()
print(self.amountArray)
所以您正在创建一个任务并启动它,然后立即打印 amountArray
。重要的是要知道该任务将异步运行,即它会定期获得处理时间直到它完成,但是您的代码的执行将在任务真正开始之前从 task.resume()
继续.所以你的 print()
在将数据添加到 amountArray
的代码发生之前很久就执行了。
如果您想查看 self.amountArray
中的内容,请移动 print()
语句,使其成为任务完成 block 中发生的最后一件事。它会在数组更改后发生。
关于ios - 为什么我的金额数组没有返回任何内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33586255/