• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 涉及 CGPathAddLineToPoint 的不可重现的崩溃错误

[复制链接]
菜鸟教程小白 发表于 2022-12-12 20:50:36 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我一直在处理我的 iPhone 应用程序中的一个有害的崩溃错误,该错误在从 App Store 下载的版本中始终可以重现,但在调试版本中完全没有。我已经提出了一种解决方法,它通过在 UIViewController 动画期间排除关键的绘图代码来工作。

  • 崩溃日志表明 CGPathAddLineToPoint 中存在断言失败。
  • 应用程序使用绘图函数 CGContextMoveToPoint、CGContextAddLineToPoint 和 CGContextStrokePath。还使用了函数 CGPathCreateMutable、CGPathAddLines 和 CGContextAddPath,但即使在(应该)避免调用它们的配置中,应用仍然会崩溃。
  • 当 UIViewController 正在呈现(动画)时,当在 View 上绘制线条时,崩溃总是会发生。否则,绘图工作没有问题。
  • 我已经在调试版本中确认,绘制的每条线的每个点都是真实的,并且在 View 的边界内。
  • 尝试绘图时,应用程序在 iOS7 上立即崩溃。在 iOS5 和 iOS6 上,应用在崩溃前停止响应 30 秒,留下一个“未知”崩溃日志,没有任何信息。
  • 我能在网络上找到的与此问题类似的唯一案例是 OS X 应用中的 CGPathAddLineToPoint 中的 CGFloatIsValid 断言失败(包括发布到 Apple 支持论坛的 iPhoto 崩溃日志)。

我不能说更多,因为该应用从不会崩溃,甚至在调试版本中也不会发出警告。有没有其他人遇到过这个错误?有没有更好的方法来解决这个问题?

您可以在发行版 on the App Store 中查看实际的解决方法.您可以看到,当计算器处于 2D 模式时,当您按下 [Graph] 按钮时,图形上的线条绘制会延迟到动画完成后。

崩溃日志的重要部分(来自运行 iOS 7.0.3 的 iPhone 5S,应用 armv7):

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:ayer::display_() + 1115
12  QuartzCore                      0x320d7365 CA:ayer::display_if_needed(CA::Transaction*) + 205
13  QuartzCore                      0x320d6ffd CA:ayer::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:bserver_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



Best Answer-推荐答案


几件事:

尝试在您在应用商店中提交版本的机器上打开崩溃日志。该版本应该包含包含符号文件的存档,您需要符号化崩溃日志。

如果你只是在你的 View Controller 被动画到屏幕上时向路径添加行时崩溃,为什么不将代码添加到调用 presentViewController:animated:completion: 的完成 block 中调用启用绘图的方法。设置您的 View Controller ,以便在首次显示时禁用绘图,并通过完成 block 中的方法调用启用。

关于ios - 涉及 CGPathAddLineToPoint 的不可重现的崩溃错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22650582/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap