GPPSignIn sharedInstance - > EXC_BAD_ACCESS(code = EXC_I386_GPFLT)

Dmi*_*sky 6 nszombie ios google-plus

似乎很长一段时间一切都很好,昨天没有任何可见的原因我开始出错

EXC_BAD_ACCESS (code = EXC_I386_GPFLT) 
Run Code Online (Sandbox Code Playgroud)

在模拟器的下一行(在真实设备上一切正常):

GPPSignIn *signIn = [GPPSignIn sharedInstance];
Run Code Online (Sandbox Code Playgroud)

启用NSZombie消息后更改为

exc_breakpoint (code=exc_i386_bpt subcode=0x0).

这很奇怪,因为即使这行只是viewDidLoad中的一行而且它是应用程序中的第一个视图控制器,我会一次又一次地得到错误(〜每3-4个应用程序启动).我没有对应用配置进行任何更改.

我将不胜感激任何帮助.谢谢!

UPD:发生错误 libobjc.A.dylib

我所看到的.

UPD: 在此输入图像描述

UPD:

2014-03-31 13:54:13.611 SomeApp[450:3c07] *** -[CFString retain]: message sent to deallocated instance 0x10c2ef050
(lldb) bt
* thread #6: tid = 0x2a3b, 0x0000000103978cc4 CoreFoundation`___forwarding___ + 772, queue = 'NSOperationQueue 0x10ea2b870', stop reason = EXC_BREAKPOINT (code=EXC_I386_BPT, subcode=0x0)
  * frame #0: 0x0000000103978cc4 CoreFoundation`___forwarding___ + 772
    frame #1: 0x0000000103978938 CoreFoundation`__forwarding_prep_0___ + 120
    frame #2: 0x00000001039fb3c7 CoreFoundation`+[__NSArrayI __new:::] + 87
    frame #3: 0x000000010395d386 CoreFoundation`+[NSArray arrayWithObjects:] + 566
    frame #4: 0x00000001002dea06 SomeApp `+[GPPSignIn versionFromServerData:currentVersion:] + 832
    frame #5: 0x00000001002dec24 SomeApp `__28-[GPPSignIn checkSDKVersion]_block_invoke + 197
    frame #6: 0x0000000100277e64 SomeApp `-[GTMHTTPFetcher connectionDidFinishLoading:] + 714
    frame #7: 0x000000010152036b Foundation`__65-[NSURLConnectionInternal _withConnectionAndDelegate:onlyActive:]_block_invoke + 48
    frame #8: 0x000000010145763b Foundation`-[NSBlockOperation main] + 75
    frame #9: 0x00000001014a5d34 Foundation`-[__NSOperationInternal _start:] + 623
    frame #10: 0x00000001014a7c0b Foundation`__NSOQSchedule_f + 64
    frame #11: 0x000000010414372d libdispatch.dylib`_dispatch_client_callout + 8
    frame #12: 0x0000000104131eab libdispatch.dylib`_dispatch_async_redirect_invoke + 174
    frame #13: 0x000000010414372d libdispatch.dylib`_dispatch_client_callout + 8
    frame #14: 0x0000000104133b27 libdispatch.dylib`_dispatch_root_queue_drain + 380
    frame #15: 0x0000000104133d12 libdispatch.dylib`_dispatch_worker_thread2 + 40
    frame #16: 0x0000000104490ef8 libsystem_pthread.dylib`_pthread_wqthread + 314
(lldb) 
Run Code Online (Sandbox Code Playgroud)

jda*_*day 2

这是一个需要追踪的奇怪问题。我只在模拟器中遇到了同样的崩溃问题[CFString retain]:(在设备上运行良好),但是当我尝试在仪器中运行僵尸时,它永远不会显示僵尸。

CFString 在 iOS 模拟器上保留问题

经过大量搜索后,您的问题促使我使用 backtrace 命令来找出 Google+ SDK 导致了该问题。

虽然这只是 Google 修复问题之前的一种解决方法,但您可以通过将您的应用程序包装GPPSignIn在预编译器指令中来检查您是否正在模拟器中运行,从而使您的应用程序在模拟器上运行:

#if !(TARGET_IPHONE_SIMULATOR)
- (GPPSignIn *) googlePlusSession {
    NSLog(@"Not running on simulator");
    if(_googlePlusSession == nil) {
        _googlePlusSession = [GPPSignIn sharedInstance];
        _googlePlusSession.clientID = kGoogleClientId;
        _googlePlusSession.scopes = [NSArray arrayWithObjects:kGTLAuthScopePlusLogin,nil];
        _googlePlusSession.delegate = self;
        [_googlePlusSession trySilentAuthentication];
    }
    return _googlePlusSession;
}
#endif
Run Code Online (Sandbox Code Playgroud)

显然,当在模拟器上运行时,这会破坏应用程序中的 Google+ 功能,但就我而言,这比根本无法启动要好得多。希望这可以帮助。