简体   繁体   English

应用程序委托-快速加载核心数据

[英]App Delegate - Load Core Data Swift

My app crashes every time using the abort function- core data. 每次使用中止功能核心数据,我的应用程序都会崩溃。 It crashes because of this code. 由于此代码而崩溃。 What is wrong with it? 怎么了

     import UIKit
     import CoreData

   class MyWordsTableViewController: UITableViewController, NSFetchedResultsControllerDelegate {


var myList: Array<AnyObject> = []


override func viewDidLoad() {
    super.viewDidLoad()


    let appDel = UIApplication.sharedApplication().delegate as! AppDelegate
    let context = appDel.managedObjectContext
    let freq = NSFetchRequest(entityName: "List")

    do {
   try myList = context.executeFetchRequest(freq)

    } catch {
     print("error")
    }

    tableView.reloadData()

Delegate for tableview are not added in your code. 未在代码中添加表视图的委托。

Add these in your view controller 将它们添加到您的视图控制器中

    class MyWordsTableViewController: UIViewController, UITableViewDataSource, UITableViewDelegate{

Add this code in your viewDidLoad 将此代码添加到您的viewDidLoad中

   self.Tablename.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell")

    Tablename.dataSource = self
    Tablename.delegate = self
    searchBar.delegate = self

For core data try the following code 对于核心数据,请尝试以下代码

var appDel: AppDelegate = (UIApplication.sharedApplication().delegate as AppDelegate)
var context: NSManagedObjectContext = appDel.managedObjectContext!

var fetchRequest = NSFetchRequest(entityName: "List")

if let fetchResults = appDel.managedObjectContext!.executeFetchRequest(fetchRequest, error: nil) as? [NSManagedObject] {
   if fetchResults.count != 0{

     println(fetchResults)
   }
}

Try this, worked for me (swift 2 Xcode 7 beta 5): (I did changes to fit your code) 尝试一下,为我工作(swift 2 Xcode 7 beta 5):(我做了一些更改以适合您的代码)

    import UIKit
    import CoreData

    var myList: Array<AnyObject> = []

    class MyWordsTableViewController: UITableViewController, NSFetchedResultsControllerDelegate
    {
        override func viewDidLoad()
        {

              super.viewDidLoad()

        }

        override func viewDidAppear(animated:Bool)
        {
            //reference to app delegate

            let appDel: AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate

            //reference NSManaged object context

            let context: NSManagedObjectContext = appDel.managedObjectContext!


            let freq = NSFetchRequest(entityName: "List")


            do
            {
                try myList = context.executeFetchRequest(freq)


                NSLog("Number of rows (App): \(myList.count)") 
            } catch _ { NSLog("That went badly...") }

            tableView.reloadData()


        }
  }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM