单步执行调试器时,EXC_BAD_ACCESS(代码= 1,地址= 0x0)

时间:2013-10-25 06:50:34

标签: ios xcode debugging xcode5 osx-mavericks

我的应用程序每次尝试跳过一个电话时都会崩溃。没有调试器它工作正常。

此外,当我在模拟器中运行应用程序时,无论是否使用调试器都可以运行。

最近我将Mac OS X 10.8升级到了10.9(Mavericks)。升级前没有问题。

导致问题的原因是什么?我该如何解决?

下面是回溯。我的应用程序使用ARC。我已启用僵尸并添加了异常断点但没有检测到僵尸,并且永远不会触发异常断点。

    * thread #1: tid = 0x2503, 0x00000000, queue = 'com.apple.main-thread, stop reason = EXC_BAD_ACCESS (code=1, address=0x0)
        frame #0: 0x00000000
        frame #1: 0x35e170c4 UIKit`-[UIApplication sendAction:to:from:forEvent:] + 72
        frame #2: 0x35e17076 UIKit`-[UIApplication sendAction:toTarget:fromSender:forEvent:] + 30
        frame #3: 0x35e17054 UIKit`-[UIControl sendAction:to:forEvent:] + 44
        frame #4: 0x35e1690a UIKit`-[UIControl(Internal) _sendActionsForEvents:withEvent:] + 502
        frame #5: 0x35e16e00 UIKit`-[UIControl touchesEnded:withEvent:] + 488
        frame #6: 0x35d3f5f0 UIKit`-[UIWindow _sendTouchesForEvent:] + 524
        frame #7: 0x35d2c800 UIKit`-[UIApplication sendEvent:] + 380
        frame #8: 0x35d2c11a UIKit`_UIApplicationHandleEvent + 6154
        frame #9: 0x37a1e5a2 GraphicsServices`_PurpleEventCallback + 590
        frame #10: 0x37a1e1d2 GraphicsServices`PurpleEventCallback + 34
        frame #11: 0x33ef9172 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 34
        frame #12: 0x33ef9116 CoreFoundation`__CFRunLoopDoSource1 + 138
        frame #13: 0x33ef7f98 CoreFoundation`__CFRunLoopRun + 1384
        frame #14: 0x33e6aebc CoreFoundation`CFRunLoopRunSpecific + 356
        frame #15: 0x33e6ad48 CoreFoundation`CFRunLoopRunInMode + 104
        frame #16: 0x37a1d2ea GraphicsServices`GSEventRunModal + 74
        frame #17: 0x35d80300 UIKit`UIApplicationMain + 1120
        frame #18: 0x000faac8 MyApp`main(argc=1, argv=0x2fd0fd08) + 116 at main.m:16

编辑:

我有最新的Xcode版本5.0.1(5A2053)。

我已经从头开始创建新的应用程序并且没有问题地运行它。然后我在ViewController的{​​{1}}中放了一个断点并尝试跳过。在这里我又遇到了一次崩溃

viewDidLoad

编辑2:

{p {3}}中的格雷格克莱顿建议关注

* thread #1: tid = 0x2503, 0x3bb9d7c4 libobjc.A.dylib`objc_msgSendSuper2 + 4, queue = 'com.apple.main-thread, stop reason = EXC_BAD_ACCESS (code=1, address=0x4)
    frame #0: 0x3bb9d7c4 libobjc.A.dylib`objc_msgSendSuper2 + 4
    frame #1: 0x000b913a test`-[ViewController viewDidLoad](self=0x1cda5c70, _cmd=0x361bd5db) + 62 at ViewController.m:19
    frame #2: 0x35d4b594 UIKit`-[UIViewController loadViewIfRequired] + 364
    frame #3: 0x35d8bd78 UIKit`-[UIWindow addRootViewControllerViewIfPossible] + 64
    frame #4: 0x35d87aec UIKit`-[UIWindow _setHidden:forced:] + 364
    frame #5: 0x35dc91e8 UIKit`-[UIWindow makeKeyAndVisible] + 60
    frame #6: 0x35d8c83e UIKit`-[UIApplication _callInitializationDelegatesForURL:payload:suspended:] + 1666
    frame #7: 0x35d8484a UIKit`-[UIApplication _runWithURL:payload:launchOrientation:statusBarStyle:statusBarHidden:] + 698
    frame #8: 0x35d2cc38 UIKit`-[UIApplication handleEvent:withNewEvent:] + 1004
    frame #9: 0x35d2c6cc UIKit`-[UIApplication sendEvent:] + 72
    frame #10: 0x35d2c11a UIKit`_UIApplicationHandleEvent + 6154
    frame #11: 0x37a1e5a2 GraphicsServices`_PurpleEventCallback + 590
    frame #12: 0x37a1e1d2 GraphicsServices`PurpleEventCallback + 34
    frame #13: 0x33ef9172 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 34
    frame #14: 0x33ef9116 CoreFoundation`__CFRunLoopDoSource1 + 138
    frame #15: 0x33ef7f98 CoreFoundation`__CFRunLoopRun + 1384
    frame #16: 0x33e6aebc CoreFoundation`CFRunLoopRunSpecific + 356
    frame #17: 0x33e6ad48 CoreFoundation`CFRunLoopRunInMode + 104
    frame #18: 0x35d83484 UIKit`-[UIApplication _run] + 668
    frame #19: 0x35d80300 UIKit`UIApplicationMain + 1120
    frame #20: 0x000b93bc test`main(argc=1, argv=0x2fd51d30) + 116 at main.m:16
    frame #21: 0x3bfd9b20 libdyld.dylib`start + 4

我做了两件事但没有帮助。

我尝试使用其他设备,但它有所不同。如果我在iOS 6.1上使用iPod Touch但iOS 7.0的iPad工作正常,则仍有例外情况。

因此,问题似乎与设备上安装的iOS版本有关。我仍然不确定如何解决它。

编辑3:

我的命令行工具版本与我的Xcode版本匹配(实际上我只有一个版本的命令行工具)。

问题可能与正在调试的代码无关。它与Xcode创建的新创建的单视图应用程序崩溃。当踩到琐碎的代码时,它会崩溃:

Others have seen this issue.
A few things to try:
1 - Reboot your device and try again. The theory is an old developer disk image is already mounted and won't be unmounted until you reboot.
2 - Re-install the OS on the device

Hopefully #1 fixes your issue. Others have done #2 and had their issue fixed, but hopefully it doesn't require an OS re-install.

我在Apple开发者论坛上XCode 5 Crashes while running the app on device并得到了Jason Molenda的回应:

  

我们正在跟踪一个听起来像你在这里看到的错误。它是   一个微妙的计时问题,需要稍慢的主机或   一个稍微慢一点的设备。它主要是iPhone 4和类似的   这将在iOS 7中看到这一点。使用iOS 6,iPhone 4和iPhone 3GS   设备最有可能体验它。 ......这个问题只会   与Xcode 5.0.1一起发生。

所以,似乎这是Xcode中的一个错误。

3 个答案:

答案 0 :(得分:23)

好的,这绝对是Xcode 5.0.1中的一个错误。

Jason Molenda on Apple Developer Forum证实了这一点。目前唯一的解决方法是使用older version of Xcode和旧版本的Mac OS X,因为Xcode 5需要OS X 10.8.4。

此问题尚无公布的ETA修复程序。关于Apple开发者论坛上关于ETA的直接问题没有答案。

2013年11月6日更新:

今天,developer.apple.com上发布了Xcode 5.0.2的预发布版本。此版本修复了(除其他事项外)以下问题:

  

在运行iOS 6.x的设备上调试应用程序会导致   应用程序崩溃与EXC_BAD_ACCESS。这已经解决了。   (15310896)

我已经安装了新版本,问题确实消失了。现在我可以再次在我的6.x设备上调试应用程序。

thread on Apple Developer Forum的杰森·莫伦达说:

  

我被告知您可以使用此Xcode 5.0.2将应用程序提交到应用程序商店   种子。

答案 1 :(得分:3)

我确认我有完全相同的错误。我的应用程序运行正常 升级到Xcode 5和Mavericks代码后工作,但是当我调试时,我无法跳过某些行,因为我得到了EXC_BAD_ACCESS。

所以我必须记住我无法通过Step Over传递的线条,并在这些线条之后放置断点或使用Continue to Line跳过这些有问题的线条。

<强> PS

下载Xcode 5.0.2 GM seed并进行调试要好得多。到目前为止,我花了30分钟使用新的Xcode。

答案 2 :(得分:3)

请登录开发者网站并下载Xcode 5.0.2 GM seed,它修复了这个错误 请参阅release notes

2013年11月12日更新
Xcode 5.0.2已发布,您可以从Dev Center

下载
相关问题