【发布时间】:2015-04-30 19:59:31
【问题描述】:
我正在使用 Swift 开发一个 iOS 应用程序。该应用程序以 Apple Maps 为中心。我是 iOS 开发的新手。我正在使用Fabric.io 测试分发应用程序并获取崩溃报告。但是,我收到的许多崩溃报告都不是很有帮助。有时崩溃报告只指定崩溃发生的方法,但不给我任何关于它为什么崩溃的线索。 我正在尝试了解这是否是标准的,或者我是否应该切换到另一个崩溃报告服务。
以下是此类崩溃报告的示例:
Crashed: com.apple.main-thread
EXC_BREAKPOINT UNKNOWN at 0x00000001000a68f8
Thread : Crashed: com.apple.main-thread
0 <APP NAME> 0x00000001000a68f8 <APP NAME>.MapViewController.(getMapAnnotations (<APP NAME>.MapViewController) -> (Swift.Double, long : Swift.Double) -> ()).(closure #1).(closure #1) (MapViewController.swift)
1 <APP NAME> 0x00000001000a6570 <APP NAME>.MapViewController.(getMapAnnotations (<APP NAME>.MapViewController) -> (Swift.Double, long : Swift.Double) -> ()).(closure #1).(closure #1) (MapViewController.swift)
2 libdispatch.dylib 0x0000000192ed13ac _dispatch_call_block_and_release + 24
3 libdispatch.dylib 0x0000000192ed136c _dispatch_client_callout + 16
4 libdispatch.dylib 0x0000000192ed5980 _dispatch_main_queue_callback_4CF + 932
5 CoreFoundation 0x00000001820f9fa4 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 12
6 CoreFoundation 0x00000001820f804c __CFRunLoopRun + 1492
7 CoreFoundation 0x00000001820250a4 CFRunLoopRunSpecific + 396
8 GraphicsServices 0x000000018b1bf5a4 GSEventRunModal + 168
9 UIKit 0x0000000186956aa4 UIApplicationMain + 1488
10 <APP NAME> 0x00000001000f1914 main (AppDelegate.swift:16)
11 libdyld.dylib 0x0000000192efaa08 start + 4
这是发生错误的方法的方法定义:
func getAnnotations(lat: Double, long: Double){ // ignore the lat long arguments
var apiWrapper = apiWrapper()
apiWrapper.search(completionHandler: {(error: NSError?, mediaElements: [MediaElement]?) in
if error == nil {
dispatch_async(dispatch_get_main_queue(), {
self.myMapView!.removeAnnotations(self.myMapView!.annotations)
self.mediaAnnotations = []
for m in mediaElements! {
var annotation = CustomAnnotation(lat: m.lat,long: m.long, mediaTuple: (media.url, media.type))
self.mediaAnnotations.append(annotation)
}
self.reorganizeAnnotations(self.mediaAnnotations)
})
}
})
}
【问题讨论】:
-
为什么不直接发布导致应用程序崩溃的代码?
-
忘记了 :) 虽然我的问题不是针对这个特定错误获得帮助,但更多的是关于为什么崩溃报告不是很有帮助(意味着不报告发生崩溃的行号或原因)
-
根据我的经验,导致此崩溃的最常见原因是强制转换 (
foo as SomeClass),但foo实际上并不是那个类。 -
这很正常,但 Swift 还不是很擅长。 (它在 Swift 1.2 中更好,但你还不能用它发布到 App Store。)
-
这有什么更新吗?我有 2% 的用户遇到同样的问题,我无法复制错误,这让我很生气!