我遇到了一些代码的问题,它实际上在xCode 6(使用ios 8.1)中工作,但不适用于7.1(和ios 9.1)。
我有一个表视图,其中自定义单元格由核心数据中的信息填充。在我的测试中,Szenario 1的条目是coredata。在每个单元格中,我对另一个核心数据实体进行计数(表示下一个详细视图中相关条目的数量)。在我的testszenario中,这个实体没有相关的条目。
不幸的是,我在xcode 7.1中得到了一个错误(在解开可选值时意外发现了Nil),无法分辨它来自何处。
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath) as! UI_Buyer_My_Bubbles_Cell
if let buyers_bubbles = fetchedResultsController?.objectAtIndexPath(indexPath) as? Buyer_My_Bubbles {
cell.label_seller?.text = buyers_bubbles.user_seller_name
cell.label_points?.text = "\(buyers_bubbles.points_buyer_collected) bubbles"+"\r\n"+"gesammelt"
cell.label_image?.image = UIImage(data:buyers_bubbles.user_seller_logo!)
if ((buyers_bubbles.user_seller_no_devices=="1") || (cell.label_image.image == nil)) {
cell.label_image?.image = UIImage(named: "no_logo")
}
//Count the number of offers
var offer_count = 0
do {
let managedObjectContext2 = (UIApplication.sharedApplication().delegate as! AppDelegate).managedObjectContext
let fetchRequest = NSFetchRequest(entityName: "Buyer_My_Offers")
var error: NSError?
let fetchedResults = try managedObjectContext2!.executeFetchRequest(fetchRequest) as? [Buyer_My_Offers]
if let results = fetchedResults {
if results.count==0{
for (var i=0; i < results.count; i++)
{
if (results[i].offer_seller_id == buyers_bubbles.user_seller_id) {
offer_count = offer_count + 1
}
}
}
}
if offer_count == 1 {
cell.label_no_offers.text = "\(String(offer_count)) Prämie"
}
if offer_count == 0 {
cell.label_no_offers.text = "Keine "+"\r\n"+"Prämien"
}
if offer_count > 1 {
cell.label_no_offers.text = "\(String(offer_count)) Prämien"
}
}
catch {print("Unable to complete request. \(error)")}
}
return cell
}
答案 0 :(得分:0)
你永远不应该在你的cellForRowAtIndexPath中做任何fetchRequest - 因为这会让你的应用程序挂起(在滚动时重新加载你的数据)。
在ViewDidLoad中加载结果,并在需要时刷新它们。
像:
viewDidLoad中:
加载核心数据对象
重新加载TableView