получить черный экран при интеграции CoreData в мое приложение ToDo Swift - PullRequest
1 голос
/ 08 февраля 2020

Я изучаю Swift из онлайн-курса, и пока мой инструктор интегрирует CoreData в свой существующий код, она создает новую базовую модель данных и копирует-вставляет App Delegate. Но в ее DataModel нет SceneDelegate, а есть в моем.

Проблема в том, что я не могу делать то же самое, что и она, из-за этих различий. Поэтому я скопировал файл SceneDelegate.swift в свой проект Xcode и скопировал другие вещи из DataModel App Delegate.

После этого решения у меня появился черный экран.

Не знаю, мне нужно добавить она и мое приложение делегированы или нет, но различия есть, пока у меня нет applicationWillResignActive, applicationDidEnterBackgraound, et c. в делегате приложения Core Data Model она имеет.

Как я могу интегрировать CoreData в мой проект, когда есть эти различия?

Спасибо!

это мое приложение файл делегата

import UIKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?


    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {


        return true
    }

    func applicationWillResignActive(_ application: UIApplication) {

    }

    func applicationDidEnterBackground(_ application: UIApplication) {

    }

    func applicationWillEnterForeground(_ application: UIApplication) {

    }

    func applicationDidBecomeActive(_ application: UIApplication) {

    }

    func applicationWillTerminate(_ application: UIApplication) {

    }
}

1 Ответ

0 голосов
/ 09 февраля 2020

Вам нужны следующие строки кода:

// MARK: - Core Data stack

lazy var persistentContainer: NSPersistentContainer = {
    /*
     The persistent container for the application. This implementation
     creates and returns a container, having loaded the store for the
     application to it. This property is optional since there are legitimate
     error conditions that could cause the creation of the store to fail.
    */
    let container = NSPersistentContainer(name: "TestCoreData")
    container.loadPersistentStores(completionHandler: { (storeDescription, error) in
        if let error = error as NSError? {
            // Replace this implementation with code to handle the error appropriately.
            // fatalError() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.

            /*
             Typical reasons for an error here include:
             * The parent directory does not exist, cannot be created, or disallows writing.
             * The persistent store is not accessible, due to permissions or data protection when the device is locked.
             * The device is out of space.
             * The store could not be migrated to the current model version.
             Check the error message to determine what the actual problem was.
             */
            fatalError("Unresolved error \(error), \(error.userInfo)")
        }
    })
    return container
}()

// MARK: - Core Data Saving support

func saveContext () {
    let context = persistentContainer.viewContext
    if context.hasChanges {
        do {
            try context.save()
        } catch {
            // Replace this implementation with code to handle the error appropriately.
            // fatalError() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
            let nserror = error as NSError
            fatalError("Unresolved error \(nserror), \(nserror.userInfo)")
        }
    }
}

Поместите его после функции applicationWillTerminate, но в классе AppDelegate.

Код автоматически добавляется при создании проекта Xcode и установите флажок «Использовать основные данные». Вы всегда можете создать новый проект Xcode, установите флажок «Использовать основные данные», а затем скопируйте и вставьте код в конец автоматически созданного AppDelegate.

...