我可以在Objective-C中执行此操作,但我在查找如何使其在Swift中工作时遇到了麻烦。我在NSManagedObject上编写了一个扩展,这样我就可以随时调用一个函数来创建一个新实体。然后,该函数将检查现有实体是否匹配,如果没有匹配,该函数将创建新实体并将其返回。如果匹配,则返回匹配。这是我的代码:
extension Chapter {
class func createChapter(i_d: Int, team_level: Int, location: String, name: String, school: String, image: UIImage, context: NSManagedObjectContext) -> Chapter {
var chapter : Chapter?
var request : NSFetchRequest = NSFetchRequest(entityName: "Chapter")
request.predicate = NSPredicate(format: "i_d = \(i_d)")
var error : NSError?
var results : [Chapter] = context.executeFetchRequest(request, error: &error) as [Chapter]
if error != nil{
println(error)
} else if results.count == 1 {
println("Only found one Chapter match for id: \(i_d)")
chapter = results.first!
} else if results.count > 1 {
println("Found multiple Chapters for id: \(i_d)")
for chapter in results {
println(chapter.name)
}
} else {
chapter = NSEntityDescription.insertNewObjectForEntityForName("Chapter", inManagedObjectContext: context) as? Chapter
chapter?.i_d = i_d
chapter?.team_level = team_level
chapter?.location = location
chapter?.name = name
chapter?.school = school
chapter?.image = UIImagePNGRepresentation(image)
var error: NSError? = nil
if !context.save(&error) {
println("Saving error \(error), \(error?.userInfo)")
} else {
println("Saved a Chapter with id: \(i_d)")
}
}
return chapter!
}
}
这就是我以前在Objective-C(粗略翻译)中调用类似内容的方式:
Chapter *chapter = [Chapter createChapterWithID:i_d, team_level:team_level, location:location, name:name, school:school, image:image, context:context];
每当我尝试 var chap:Chapter = Chapter.createChapter(...)之类的东西时,Xcode只允许我在参数列表中放入另一个Chapter对象,而如果我尝试调用该函数从章节实例中,函数参数可以填写正确。
我将如何解决我的问题?
根据答案建议,我通过放置" class"来修复我的代码。在我的函数定义前面,以及在函数中正确创建我的初始变量,并在必要的地方添加问号。
答案 0 :(得分:1)
您可以尝试创建一个便利初始化。
http://devmonologue.com/ios/swift/swift-initializers-designated-convenience/
还要注意,如果你想做Chapter.createChapter(),createChapter需要是一个类func,在你的扩展中它只是一个常规的func。所以它期望章对象创建对象,而不是类。
更改
func createChapter ...
到
class func createChapter ...