线程1:EXC_BAD_INSTRUCTION(代码= EXC_I386_INVOP,子码= 0 * 0)错误

问题描述:

我得到的错误:线程1:EXC_BAD_INSTRUCTION(代码= EXC_I386_INVOP,子码= 0 * 0)错误

1:EXC_BAD_INSTRUCTION(code=EXC_I386_INVOP,subcode=0*0)

我是新来的编码和我下面这个视频https://www.youtube.com/watch?v=Fv-A8lKn7VY

代码如下:

import UIKit 
import CoreData 

class SwiftCoreDataHelper: NSObject { 

    class func directoryForDatabaseFilename()->NSString{ 
     return NSHomeDirectory().stringByAppendingString("/Library/Private Documents") 
    } 

    class func databaseFilename()->NSString{ 
     return "database.sqlite"; 
    } 

    class func managedObjectContext()->NSManagedObjectContext{ 


     do { try NSFileManager.defaultManager().createDirectoryAtPath(SwiftCoreDataHelper.directoryForDatabaseFilename() as String, withIntermediateDirectories: true, attributes: nil) } 
     catch { 
      print("Error Creating Directory for DB") 
     } 
     //  NSFileManager.defaultManager().createDirectoryAtPath(SwiftCoreDataHelper.directoryForDatabaseFilename(), withIntermediateDirectories: true, attributes: nil, error: &error) 

     let path:NSString = "\(SwiftCoreDataHelper.directoryForDatabaseFilename()) + \(SwiftCoreDataHelper.databaseFilename())" 

     let url:NSURL = NSURL(fileURLWithPath: path as String) 

     let managedModel:NSManagedObjectModel = NSManagedObjectModel.mergedModelFromBundles(nil)! 

     let storeCoordinator:NSPersistentStoreCoordinator = NSPersistentStoreCoordinator(managedObjectModel: managedModel) 

     do { 
     try storeCoordinator.addPersistentStoreWithType(NSSQLiteStoreType, configuration: nil, URL: url, options: nil) 
     } 
     catch { 
      print("Error: \(error)") 
      } 

     let managedObjectContext = NSManagedObjectContext(concurrencyType: NSManagedObjectContextConcurrencyType.MainQueueConcurrencyType) 

     managedObjectContext.persistentStoreCoordinator = storeCoordinator 

     return managedObjectContext  
    } 

    class func insertManagedObject(className:NSString, managedObjectConect:NSManagedObjectContext)->AnyObject{ 

     let managedObject:NSManagedObject = NSEntityDescription.insertNewObjectForEntityForName(className as String, inManagedObjectContext: managedObjectConect) as NSManagedObject 

     return managedObject 

    } 

    class func saveManagedObjectContext(managedObjectContext:NSManagedObjectContext)->Bool{ 
     do { 
      try managedObjectContext.save() 
      return true 
     } catch _ { 
      return false 
     } 
    }  

    class func fetchEntities(className:NSString, withPredicate predicate:NSPredicate?, managedObjectContext:NSManagedObjectContext)->NSArray{ 
     let fetchRequest:NSFetchRequest = NSFetchRequest() 
     let entetyDescription:NSEntityDescription = NSEntityDescription.entityForName(className as String, inManagedObjectContext: managedObjectContext)! 

     fetchRequest.entity = entetyDescription 
     if (predicate != nil){ 
      fetchRequest.predicate = predicate! 
     } 

     fetchRequest.returnsObjectsAsFaults = false 
     var items = NSArray() 
     do { items = try managedObjectContext .executeFetchRequest(fetchRequest) 
     } catch { 
      print("Fetch Request Failed") 
     } 
     return items 
    } 
} 

在产生错误的代码是:

let entetyDescription:NSEntityDescription = NSEntityDescription.entityForName(className as String, inManagedObjectContext: managedObjectContext)! 

我无法纠正错误。

+2

我坚决会避免这些教程它建议将NSFileManager的基础类型('NSString','NSDictionary')而不是Swift原生类型('String','Dictionary')和'NSHomeDictionary()'而不是'URLForDirectory:inDomain:appropriateForURL:create:'在应用程序容器中指定目录。 – vadian

+0

在'NSBundle'上使用方法来获取目录位置是正确的方法。 –

entityForName返回可选值。它可能崩溃,因为你强行解开这个操作与!

结果您可以使用可选在这种情况下,结合测试是否entityForName实际上返回一个值:

if let entityDescription = NSEntityDescription.entityForName(className as String, inManagedObjectContext: managedObjectContext) { 
    // work with entityDescription 
} else { 
    // handle the case in which entityForName returns nil 
} 
+0

是的,我强行把! 'let entetyDescription:NSEntityDescription = NSEntityDescription.entityForName(className as String,inManagedObjectContext:managedObjectContext)''因为它显示可选类型NSEntityDescription的值?不解开,它弹出一个修复! – Radz

+0

是的,编译器会在运行前看到一个错误并提出一个即时解决方案。不幸的是,这些解决方案并不总是有利的 - 就像在这种情况下一样。 – ff10

+0

是的,请你给我一个解决这个错误的解决方案吗?我无法解决它 – Radz