我一直在尝试在我的应用程序中实现一个简单的核心数据功能,以便它只在应用程序第一次加载时显示教程(带有滚动页面的单独视图控制器),并且每隔一段时间就会绕过它。 我从Swift 2的CoreData教程开始使用语法,但后来不得不根据Swift 3的自动更正和其他教程进行调整,这些教程帮助我克服了我在路上发现的错误(例如SIGBRT)。我当前遇到的问题是EXC_BAD_INSTRUCTION错误,我需要帮忙修复。
我有一个带有以下代码的scrollViewController:
class ScrollViewController: UIViewController, NSFetchedResultsControllerDelegate {
@IBOutlet var mainScrollView: UIScrollView!
@IBOutlet weak var endTutorial: UIButton!
var imageArray = [UIImage]()
class Person: NSManagedObject {
@NSManaged var tutorialstatus: String?
}
func seed() {
let moc = DataController().managedObjectContext
let entityDes = NSEntityDescription.entity(forEntityName: "Person", in: moc)
let entity = Person(entity: entityDes!, insertInto: moc)
entity.tutorialstatus="test value"
do {
try moc.save()
} catch {
fatalError("Failure to save context: \(error)")
}
}
func fetch() {
let moc = DataController().managedObjectContext
let personFetch = NSFetchRequest<Person>(entityName: "Person")
do {
let fetchedPerson = try moc.fetch(personFetch)
print(fetchedPerson.first!.tutorialstatus)
} catch {
fatalError("Failed to fetch person: \(error)")
}
}
在let fetchedPerson = try moc.fetch(personFetch)
行,当我尝试编译时,我看到错误 EXC_BAD_INSTRUCTION(代码= EXC_1386_INVOP,子代码= 0x0)
我正在使用Xcode 8,Beta 8。 我有一个名为&#39; CoreDataStuf.xcdatamodeld的swift文件,它有一个名为&#34; Person&#34;的实体。使用名为tutorialstatus的属性,这是一个字符串。我还给了那个实体一类人。 我还有一个DataController.swift文件,其中我引用了URL CoreDataStuf。
答案 0 :(得分:2)
这是有用的:
let fetchedPerson = try moc.fetch(personFetch as! NSFetchRequest<NSFetchRequestResult>)
答案 1 :(得分:2)
尝试在moc上下文中这样做
@IBOutlet weak var inValue: UITextField!
let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
@IBAction func goBtn(_ sender: UIButton) {
var inVal = Int(inValue.text!)!
for i in inVal...inVal + 10 {
context.perform {
let nums = NSEntityDescription.insertNewObject(forEntityName: "Numbers", into: self.context) as! Numbers
let request:NSFetchRequest<Numbers> = Numbers.fetchRequest()
request.predicate = NSPredicate(format: "nums == %d", i)
do { let numbers = try? request.execute()
if (numbers?.count)! > 0 {
print ("Value \(i) alreayd existis")
} else {
nums.nums = Decimal(i) as NSDecimalNumber?
}
} catch let error {
print ("Error while fetching \(error)")
}
}
do {
try self.context.save()
print ("Value stored in DB \(i)")
} catch let error {
print ("Error while saving \(error)")
}
}
}
答案 2 :(得分:1)
尝试:
let personFetch = NSFetchRequest<NSFetchRequestResult>(entityName: "Person")