Ios 涉及CGPathAddLineToPoint的不可复制的崩溃错误
我一直在处理我的iPhone应用程序中的一个有害的崩溃错误,它在从应用商店下载的版本中始终是可复制的,但在调试版本中一点也没有。我已经制作了一个变通方法,它通过排除在UIViewController动画期间运行的关键绘图代码来工作Ios 涉及CGPathAddLineToPoint的不可复制的崩溃错误,ios,objective-c,crash,Ios,Objective C,Crash,我一直在处理我的iPhone应用程序中的一个有害的崩溃错误,它在从应用商店下载的版本中始终是可复制的,但在调试版本中一点也没有。我已经制作了一个变通方法,它通过排除在UIViewController动画期间运行的关键绘图代码来工作 崩溃日志表明CGPathAddLineToPoint中存在断言失败 该应用程序使用绘图函数CGContextMoveToPoint、CGContextAddLineToPoint和CGContextStrokePath。还使用了函数CGPathCreateMutab
- 崩溃日志表明CGPathAddLineToPoint中存在断言失败
- 该应用程序使用绘图函数CGContextMoveToPoint、CGContextAddLineToPoint和CGContextStrokePath。还使用了函数CGPathCreateMutable、CGPathAddLines和CGContextAddPath,但即使在(应该)避免调用它们的配置中,应用程序仍会崩溃
- 当在视图上绘制线,同时显示其UIViewController(动画)时,崩溃会持续发生。否则,图纸将不会出现问题
- 我已经在调试版本中确认,绘制的每条线的每个点都是真实的,并且在视图的边界内
- 尝试绘图时,应用程序在iOS7上立即崩溃。在iOS5和iOS6上,应用程序在崩溃前停止响应30秒,留下一个没有任何信息的“未知”崩溃日志
- 我能在网上找到的唯一与此问题类似的案例是OS X应用程序中CGPathAddLineToPoint中的CGFloatIsValid断言失败(包括苹果支持论坛上发布的iPhoto崩溃日志)
如果仅在视图控制器在屏幕上设置动画时向路径添加线时崩溃,为什么不将代码添加到调用启用绘图方法的
presentViewController:animated:completion:
调用的完成块中呢。设置视图控制器,使绘图在第一次显示时被禁用,并通过完成块中的方法调用被启用。为了澄清(对于未来的人),如果您的应用程序在动画期间崩溃,只有在应用商店版本中,才有一种解决方法,崩溃日志表明CGPathAddLineToPoint中的断言失败。只需在动画期间排除所有线条绘制代码,它就不会崩溃。它在断言中崩溃。断言消息是什么?它应该在程序的标准错误中。崩溃日志中没有对断言失败的描述。还有其他地方的信息会被记录到吗?我有一个类似的问题,在升级到Xcode 5.1.1后的iOS PhoneGap+jQuery移动应用程序上:我们有相同的神秘崩溃,在某些架构下,当你添加一个不包含任何点的路径时,CGPathAddLineToPoint看起来会阻塞。之前的一个if保存了我们。我在项目存在的唯一机器上打开了崩溃日志(以及我提交存档的机器)。当我要求Xcode对其进行符号化时,我得到的只是那些十六进制字符,在我自己的代码中没有关于崩溃发生在何处的进一步信息。
Exception Type: EXC_CRASH (SIGABRT)
Exception Codes: 0x0000000000000000, 0x0000000000000000
Triggered by Thread: 0
Thread 0 Crashed:
0 libsystem_kernel.dylib 0x3a5e11fc __pthread_kill + 8
1 libsystem_pthread.dylib 0x3a648a4f pthread_kill + 55
2 libsystem_c.dylib 0x3a592029 abort + 73
3 libsystem_c.dylib 0x3a571c67 __assert_rtn + 179
4 CoreGraphics 0x2fd566f5 CGPathAddLineToPoint + 149
5 (My App) 0x001464cd 0xd7000 + 455885
6 UIKit 0x324d4dd5 -[UIView(CALayerDelegate) drawLayer:inContext:] + 369
7 QuartzCore 0x3210aa75 -[CALayer drawInContext:] + 97
8 QuartzCore 0x320f4241 CABackingStoreUpdate_ + 1857
9 QuartzCore 0x321ce2e9 ___ZN2CA5Layer8display_Ev_block_invoke + 49
10 QuartzCore 0x320f3af1 x_blame_allocations + 81
11 QuartzCore 0x320f37a3 CA::Layer::display_() + 1115
12 QuartzCore 0x320d7365 CA::Layer::display_if_needed(CA::Transaction*) + 205
13 QuartzCore 0x320d6ffd CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 21
14 QuartzCore 0x320d6a09 CA::Context::commit_transaction(CA::Transaction*) + 225
15 QuartzCore 0x320d681b CA::Transaction::commit() + 311
16 QuartzCore 0x320d0549 CA::Transaction::observer_callback(__CFRunLoopObserver*, unsigned long, void*) + 53
17 CoreFoundation 0x2fc9bf67 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 19
18 CoreFoundation 0x2fc998f3 __CFRunLoopDoObservers + 283
19 CoreFoundation 0x2fc99c3f __CFRunLoopRun + 735
20 CoreFoundation 0x2fc0446d CFRunLoopRunSpecific + 521
21 CoreFoundation 0x2fc0424f CFRunLoopRunInMode + 103
22 GraphicsServices 0x349382e7 GSEventRunModal + 135
23 UIKit 0x324b9841 UIApplicationMain + 1133
24 (My App) 0x000de723 0xd7000 + 30499
25 (My App) 0x000dde0c 0xd7000 + 28172