注意:请参阅问题底部的更新,我已经设法在调试方面做得更进一步。
我认为这是我的项目设置的一个问题,但我不确定要查看什么,因为没有编译错误。
我在项目中包含了 MagicalRecord 2.1(当前稳定),并由 CocoaPods 管理它。我没有更改 CocoaPods 的任何构建设置,它完美地管理了我的其他依赖项,到目前为止我还没有遇到任何问题。
我已添加#import <MagicalRecord/CoreData+MagicalRecord.h>
到我的App-Prefix.pch
文件中,Xcode 为我提供了正确设置所期望的所有符号建议。我没有收到任何编译器错误,所以我只能假设 CocoaPods 已成功将 MR 构建到库中,并且我已成功将其导入到我的代码中。
当我在我的应用程序委托中初始化 MagicalRecord 时出现问题:
- (void)applicationDidFinishLaunching:(NSNotification *)notification {
[MagicalRecord setupCoreDataStack];
//... other code
}
初始化几乎是要运行的第一个代码,并且没有任何其他已运行的代码会与此冲突。
该行挂起,执行该行后没有任何内容。我设法找到了挂起发生的位置。将消息传递给MagicalRecord
会导致类+initialize
调用它,但这是行不通的。更具体地说,self
在初始化方法中调用的任何方法都会导致unrecognized selector
抛出异常。
据我所知,这有两件奇怪的事情:
- 为什么找不到方法实现?
- 为什么会导致它挂起?
我对Objective-C如何使用initialize方法知之甚少,当抛出异常时它是否会挂起?
这是发生异常时的堆栈跟踪:
frame #0: 0x00007fff93a2e3c5 libobjc.A.dylib`objc_exception_throw
frame #1: 0x00007fff996dc31a CoreFoundation`+[NSObject(NSObject) doesNotRecognizeSelector:] + 186
frame #2: 0x00007fff996341ee CoreFoundation`___forwarding___ + 414
frame #3: 0x00007fff99633fd8 CoreFoundation`_CF_forwarding_prep_0 + 232
frame #4: 0x000000010004e32c River`+[MagicalRecord initialize] + 92 at MagicalRecord.m:89
frame #5: 0x00007fff93a25236 libobjc.A.dylib`_class_initialize + 310
frame #6: 0x00007fff93a250f3 libobjc.A.dylib`prepareForMethodLookup + 164
frame #7: 0x00007fff93a24eef libobjc.A.dylib`lookUpMethod + 71
frame #8: 0x00007fff93a232fc libobjc.A.dylib`objc_msgSend + 188
frame #9: 0x0000000100001d36 MyApp`-[AppDelegate applicationDidFinishLaunching:] + 86 at AppDelegate.m:46
对此的任何帮助,包括我可以尝试进一步调试的技巧,都非常感谢。
更新:
删除我的派生数据目录后,程序无法链接到 Pod。我相信 Xcode 在我添加 MagicalRecord 并链接到它的旧版本后未能构建 Pod(这可能是错误的,我不确定)。
这似乎是 Xcode 和/或 CocoaPods 问题。我正在尝试弄清楚如何让它正确构建 Pod,但我不是 CocoaPods 或 Xcode 构建设置方面的专家,所以我不确定我能走多远。
更新 2:
Xcode 和项目设置存在问题,它与旧的 Pod 库链接,并且仅在删除派生数据后才导致问题。现在我回到第 1 格,遇到无法识别的选择器问题。