任何人都可以帮助揭开此崩溃报告的神秘面纱吗?
没有异常名称或原因,并且回溯显示在包含崩溃的init
方法的文件的第0行发生崩溃。 什么?的
Incident Identifier: TODO
CrashReporter Key: TODO
Hardware Model: iPhone7,2
Process: AppName [1112]
Path: /private/var/mobile/Containers/Bundle/Application/2632C5D7-6A07-4002-A27B-D547E9A7345C/AppName.app/AppName
Identifier: com.app.name
Version: 67
Code Type: ARM-64
Parent Process: launchd [1]
Date/Time: 2015-06-26 18:20:18 +0000
OS Version: iPhone OS 8.3 (12F70)
Report Version: 104
Exception Type: SIGTRAP
Exception Codes: TRAP_BRKPT at 0x10008c370
Crashed Thread: 0
Application Specific Information:
*** Terminating app due to uncaught exception '', reason: ''
崩溃线程的第一对符号线:
0 AppName 0x000000010008c370 init (article, $metatype) (ArticleImageProvider.swift:0)
1 AppName 0x000000010006b0c4 shareArticleActivityViewController (article, track) (BasicArticleSharingController.swift:28)
2 AppName 0x0000000100063198 sharePressed () (DetailsViewController.swift:202)
3 AppName 0x00000001000600c8 sharePressed () (DetailsViewController.swift:200)
4 AppName 0x00000001000bfa8c sharePressed () (ContentNavView.swift:108)
5 AppName 0x000000010022f4b4 __55-[ASControlNode sendActionsForControlEvents:withEvent:]_block_invoke (ASControlNode.m:360)
6 AppName 0x000000010022f21c -[ASControlNode sendActionsForControlEvents:withEvent:] (ASControlNode.m:381)
7 AppName 0x000000010022e5b8 -[ASControlNode touchesEnded:withEvent:] (ASControlNode.m:191)
8 AppName 0x000000010026185c -[_ASDisplayView touchesEnded:withEvent:] (_ASDisplayView.mm:173)
9 UIKit 0x0000000187613d8c forwardTouchMethod + 260
10 UIKit 0x00000001874b0a2c -[UIWindow _sendTouchesForEvent:] + 696
11 UIKit 0x00000001874a9f68 -[UIWindow sendEvent:] + 680
12 UIKit 0x000000018747d18c -[UIApplication sendEvent:] + 260
13 UIKit 0x000000018771e324 _UIApplicationHandleEventFromQueueEvent + 15420
14 UIKit 0x000000018747b6a0 _UIApplicationHandleEventQueue + 1712
以下是一些代码:
// Where I attach the action to my button in ContentNavView
shareButton.addTarget(self, action: "sharePressed", forControlEvents: ASControlNodeEvent.TouchUpInside)
/* snip */
// The implementation of ContentNavView#sharePressed()
func sharePressed() {
delegate.sharePressed()
}
// The implementation of DetailsViewController#sharePressed()
func sharePressed() {
if let cell = currentCell {
let activityViewController = BasicArticleSharingController.shareArticleActivityViewController(cell.article)
self.view.window?.rootViewController?.presentViewController(activityViewController, animated: true, completion: nil)
}
}
// The implementation of BasicArticleSharingController#shareArticleActivityViewController(::) up to the initializer
class func shareArticleActivityViewController(article: Article, track: Bool = true) -> UIActivityViewController {
var article = CoreDataManager.sharedManager.managedObjectContextForCurrentThread().objectWithID(article.objectID) as! Article
let activities = [
ArticleImageProvider(article: article), // Crash when calling this init?
ArticleLinkProvider(article: article)
]
/* snip */
}
// Implementation of the init that's crashing. Apparently Swift only reports the class that crashes, not the line that crashes, so here's the implementation that I thought wasn't relevant.
final public class ArticleImageProvider: UIActivityItemProvider {
let articleObjectID: NSManagedObjectID
init(article: Article) {
self.articleObjectID = article.objectID
let article: Article = CoreDataManager.sharedManager.managedObjectContextForCurrentThread().objectWithID(article.objectID) as! Article
let thumbnailCut = article.headlineImage?.cutWithShape(.Landscape)
if let path = thumbnailCut?.localURL?.path {
if let image = UIImage(contentsOfFile: path) {
super.init(placeholderItem: image)
}
else {
super.init(placeholderItem: UIImage())
}
} else {
super.init(placeholderItem: UIImage())
}
}
/* snip */
}
答案 0 :(得分:6)
所以,我在这里学到了一些东西:
objectWithID:
返回NSManagedObject
。就是这样。我们无法保证您发送该消息的对象将返回与接收方相同类型的对象,因此测试返回的对象是最安全的处理方法。作为一个必然结果,确定NSFetchRequest
以减少或消除托管对象的线程问题是一个至关重要的问题,并将完全消除这个问题。NSThread#callStackSymbols
或其他API)获取崩溃报告将始终返回我在此处显示的相同垃圾。您可以做的最好的事情是推断出可能导致崩溃的词汇范围,并针对任何可能的错误梳理代码。在Swift成熟之前,我们不得不这样做。