我的申请更新已被拒绝。在拒绝消息中,他们写了“发布时应用程序崩溃”。然后我尝试了我的应用程序,但无法使其崩溃。所以我使用了TestFlight并注意到当我从TestFlight或AppStore启动我的应用程序时,它在启动时崩溃了。但是如果我正常启动我的应用程序,它确实可以正常运行而不会崩溃。问题是自iOS 10更新以来发生了这个错误。现在,我在AppStore上发布时,我的应用程序也会崩溃,而它在2周后工作正常。
Apple给我发了一个崩溃日志:Incident Identifier: 001969F1-F275-4AC3-AFE1-E0426957B702
CrashReporter Key: 5ad9695e945a7d5eb5d61fd18d1c3989ccd155b4
Hardware Model: xxx
Process: MyApp [400]
Path: /private/var/containers/Bundle/Application/644423A4-EFE7-41B1-99D9-47B46338A6E2/MyApp.app/MyApp
Identifier: com.MyApp.com
Version: 20160527 (2.7.9)
Code Type: ARM-64 (Native)
Role: Foreground
Parent Process: launchd [1]
Coalition: com.MyApp.com [451]
Date/Time: 2016-09-22 11:19:22.6893 -0700
Launch Time: 2016-09-22 11:19:22.4164 -0700
OS Version: iPhone OS 10.0.1 (14A403)
Report Version: 104
Exception Type: EXC_BREAKPOINT (SIGTRAP)
Exception Codes: 0x0000000000000001, 0x000000010008a864
Termination Signal: Trace/BPT trap: 5
Termination Reason: Namespace SIGNAL, Code 0x5
Terminating Process: exc handler [0]
Triggered by Thread: 0
Filtered syslog:
None found
Thread 0 name: Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0 MyApp 0x1000efd3c specialized AppDelegate.application(UIApplication, didFinishLaunchingWithOptions : [NSObject : AnyObject]?) -> Bool (AppDelegate.swift:218)
1 MyApp 0x1000ed310 @objc AppDelegate.application(UIApplication, didFinishLaunchingWithOptions : [NSObject : AnyObject]?) -> Bool (AppDelegate.swift)
2 UIKit 0x19888c42c <redacted> + 400
3 UIKit 0x198a9cb70 <redacted> + 3524
4 UIKit 0x198aa28e0 <redacted> + 1656
5 UIKit 0x198ab7080 <redacted> + 48
6 UIKit 0x198a9f8c4 <redacted> + 168
7 FrontBoardServices 0x1945798bc <redacted> + 36
8 FrontBoardServices 0x194579728 <redacted> + 176
9 FrontBoardServices 0x194579ad0 <redacted> + 56
10 CoreFoundation 0x192986278 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 24
11 CoreFoundation 0x192985bc0 __CFRunLoopDoSources0 + 524
12 CoreFoundation 0x1929837c0 __CFRunLoopRun + 804
13 CoreFoundation 0x1928b2048 CFRunLoopRunSpecific + 444
14 UIKit 0x1988855dc <redacted> + 608
15 UIKit 0x198880360 UIApplicationMain + 208
16 MyApp 0x1000ee818 main (AppDelegate.swift:58)
17 libdispatch.dylib 0x1918945b8 (Missing)
还有另外4个线程,但是这一个是崩溃的,所以我没有复制其余的。我做了一些研究,虽然我确实注意到我的崩溃日志没有完全翻译(因为我有所有的dsyms但是有什么奇怪的原因),我确实理解我在第217行崩溃了(告诉我,如果我'我错了)。我知道SIGTRAP大多数时候都会抛出NSExceptions。这条线本身就是:
let api = MyAppAPI.instance
该实例是一个单例。我的猜测是实例创建中的某些内容失败了。这是代码:
static var instance: MyAppAPI = {
return Singleton.instance
}()
class MyAppAPI: Manager {
struct Singleton {
static var configuration: NSURLSessionConfiguration = {
var configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
let version = NSBundle.mainBundle().objectForInfoDictionaryKey("CFBundleShortVersionString") as? String ?? ""
configuration.HTTPAdditionalHeaders = [
"Accept": "application/vnd.MyApp.api+json, application/json;q=0.9",
"User-Agent": "MyApp iOS/\(version)",
"X-API-Version": "1.0.1"
]
return configuration
}()
static var instance = MyAppAPI(configuration: configuration)
static var baseURL : NSURL! = nil
}
我对这个错误非常绝望,我确实尝试了一些无法解决的问题。我在寻找合适的地方吗?有人有解决方案吗?任何形式的帮助将不胜感激。我愿意给任何可以找到我解决方案或帮我找到解决方案的人送礼!
答案 0 :(得分:5)
我找到了解决问题的方法。
正如所料,它来自replicate
在函数内部func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool
。
我将其更改为let userInfo = launchOpts[UIApplicationLaunchOptionsRemoteNotificationKey] as! NSDictionary
,然后选中let userInfo = launchOpts[UIApplicationLaunchOptionsRemoteNotificationKey] as? NSDictionary
以使所有代码运行if userInfo != nil
到括号中。
如果它可以帮助任何人或者是否有人在努力解决此问题,请检查所有人userInfo
并将其与!
交换,如果需要(在?
上),因为从TestFlight / AppStore启动似乎与安装的应用程序有不同的选项(只是一个猜测,不足以声称它)。