iOS:项目中疑难Crash问题集锦

简介: 项目中疑难Crash问题集锦      iOS App运行中遇到Crash的情况相信大家都遇到过,开发和者测试中遇到了可能很方便的办法就是直接拿着设备连接一下,然后使用Xcode自带的工具就可以解析出Crash地址了。

项目中疑难Crash问题集锦

  

  iOS App运行中遇到Crash的情况相信大家都遇到过,开发和者测试中遇到了可能很方便的办法就是直接拿着设备连接一下,然后使用Xcode自带的工具就可以解析出Crash地址了。对于线上App运行时的Crash收集也有很多好用的第三方工具,具有代表性的就是Crashlytics,通过打包时上传dSYM文件,收集到的Crash就可以解析为可读的格式了。

  尽管Crashlytics功能已经很强大了,统计出来的Crash信息也足够详细,还是会有一些难缠的问题,例如程序直接就挂在main函数中,剩下的就是系统的调用了。下面就聊了一下我们App中遇到的几个难缠的Crash:

1、多次弹出AlertView时存在的问题

     在我们App中有一些地方因为业务会弹出一些二次确认框,当弹出AlertView时切换到后台,接着再切到前台,快速点击触发二次确认操作,会再弹出一个AlertView,此时点击该AlertView后,之前已经弹出的AlertView会恢复出来,再点击程序就会Crash掉。在iPhone采用相同步骤验证该问题,发现无法重现,每次程序切回前台时,AlertView现场迅速恢复,由此可见该问题是iPad上才会存在。

     正常情况下程序退到后台时,系统会自动隐藏AlertView,等到下次程序切换到前台时,如果退出前弹出了AlertView,系统会恢复该AlertView的展示。问题就出现在这儿,系统恢复AlertView的展示时是有延迟的,而非立即恢复。在此时如果再触发先关时间,弹出新的AlertView,就会损坏中断的现场,从而导致程序运行状态出现异常,之后再操作可能就会Crash掉。

    这个问题当时想到了两种解决办法:

    a、在程序退到后台之前就对弹出层做默认操作

    b、程序中设置标志,标识当前是否已经弹出AlertView,如果已经弹出,再操作时就不会再弹出AlertView

    第一种方法,会存在一些问题,因为有些界面的AlertView弹出以后,点击默认操作可能会影响view层级,这样从后台再回来的时候现场界面发生变化,会给用户造成不必要的困惑。

    第二种方法,在Apps的基类里面添加一个标记位,弹出AlertView时置为YES,关闭AlertView时置为NO。当前App如果已经弹出了AlertView,则后续操作不再触发弹出AlertView的操作,这样就能避免程序从后台切回来时快速点击导致的Crash问题。

2、webview动画引发的Crash问题

    在执行自动化测试过程中,不规律的出现了几次Crash,无法找到固定的重现步骤,Crash栈如下:

Exception Type:  EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x00000008
Crashed Thread:  0

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   libobjc.A.dylib               	0x390b15b0 objc_msgSend + 16
1   UIKit                         	0x33289182 -[_UIWebViewScrollViewDelegateForwarder forwardInvocation:] + 138
2   CoreFoundation                	0x31218616 ___forwarding___ + 622
3   CoreFoundation                	0x3116ff64 _CF_forwarding_prep_0 + 20
4   UIKit                         	0x330d40c2 -[UIScrollView _getDelegateZoomView] + 98
5   UIKit                         	0x330d3fc0 -[UIScrollView _zoomScaleFromPresentationLayer:] + 24
6   UIKit                         	0x330d9fec -[UIWebDocumentView _zoomedDocumentScale] + 56
7   UIKit                         	0x330d6ae8 -[UIWebDocumentView _layoutRectForFixedPositionObjects] + 100
8   UIKit                         	0x3327b292 -[UIWebDocumentView _updateFixedPositionedObjectsLayoutRectUsingWebThread:synchronize:] + 38
9   UIKit                         	0x330dc6d4 -[UIWebDocumentView _updateFixedPositioningObjectsLayoutAfterScroll] + 24
10  UIKit                         	0x330dc6b0 -[UIWebBrowserView _updateFixedPositioningObjectsLayoutAfterScroll] + 52
11  UIKit                         	0x330dc566 -[UIWebDocumentView _restoreScrollPointForce:] + 502
12  UIKit                         	0x330dc25c -[UIWebDocumentView _resetForNewPage] + 408
13  UIKit                         	0x330a84c4 -[UIWebDocumentView layoutSubviews] + 72
14  UIKit                         	0x330217fe -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 254
15  QuartzCore                    	0x32dcbd86 -[CALayer layoutSublayers] + 210
16  QuartzCore                    	0x32dcb924 CA::Layer::layout_if_needed(CA::Transaction*) + 456
17  QuartzCore                    	0x32dcc858 CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 12
18  QuartzCore                    	0x32dcc23e CA::Context::commit_transaction(CA::Transaction*) + 234
19  QuartzCore                    	0x32dcc04c CA::Transaction::commit() + 312
20  UIKit                         	0x330278e6 _afterCACommitHandler + 122
21  CoreFoundation                	0x311eb6ca __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 18
22  CoreFoundation                	0x311e99bc __CFRunLoopDoObservers + 272
23  CoreFoundation                	0x311e9d12 __CFRunLoopRun + 738
24  CoreFoundation                	0x3115ceb8 CFRunLoopRunSpecific + 352
25  CoreFoundation                	0x3115cd44 CFRunLoopRunInMode + 100
26  GraphicsServices              	0x34d262e6 GSEventRunModal + 70
27  UIKit                         	0x330722fc UIApplicationMain + 1116
28  MyApp                     	        0x0000fc60 main (main.m:15)
29  libdyld.dylib                 	0x394edb1c start + 0

  Crash栈咋一看,挂在系统的API调用上,再仔细看一下报EXC_BAD_ACESS错误,应该是对象被释放后导致了野指针调用问题。仔细查看Apps中调用到Webview的地方发现,使用方法没什么问题。网上搜索了一下发现,该问题可能是由于webview在动画中,持有者(VC)已经被释放导致的。

  解决办法:在所有持有Webview的对象释放前都添加了Webview的delegate置空操作。

  在自动化测试中tableview,scrollview也遇到了Webview相似的问题,因此就在程序中相关地方都做了保护处理,之后自动化测试中该类问题没有再出现过。

  一点感想:拿到Crash栈,一看是挂在系统调用,估计就不想花时间解决了。有时候坚持一下,多看一会儿,多想一下,尝试去Google上搜一下Crash信息中的一些字段,或许别人也有遇到过相同或者相似的问题,说不定得到启发从而解决了一个看似没法解决的问题。

 

注:smileEvday保留本文的一切权利

  转载请著名原文出处

  本文在开发过程中随时更新,欢迎交流


部门招人: 高级iOS、Android、前端开发,有意私聊,博主请你喝️
如果觉得本文帮到了你,记得点赞哦,当然也可以请博主喝一杯豆浆
微信二维码 QQ二维码
目录
相关文章
|
Web App开发 数据安全/隐私保护 iOS开发
app优化ios,iOS app上架流程问题集锦,ASO新手小白必看(上)
app优化ios,iOS app上架流程问题集锦,ASO新手小白必看(上)
|
3月前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
129 1
|
4月前
|
IDE Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【9月更文挑战第27天】在移动应用开发的世界中,Android和iOS是两个主要的操作系统平台。每个系统都有其独特的开发环境、工具和用户群体。本文将深入探讨这两个平台的关键差异点,并分析这些差异如何影响应用的性能、用户体验和最终的市场表现。通过对比分析,我们将揭示选择正确的开发平台对于确保项目成功的重要作用。
|
7月前
|
存储 安全 编译器
我给 iOS 系统打了个补丁——修复 iOS 16 系统键盘重大 Crash
我给 iOS 系统打了个补丁——修复 iOS 16 系统键盘重大 Crash
171 2
我给 iOS 系统打了个补丁——修复 iOS 16 系统键盘重大 Crash
|
6月前
|
Java Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【7月更文挑战第8天】在移动应用开发的广阔天地中,Android与iOS两大平台各自占据着半壁江山。本文将深入探讨这两个平台在开发环境、用户界面设计、性能优化以及市场覆盖等方面的根本差异,并分析这些差异如何影响项目的成功。通过比较和分析,旨在为开发者在选择平台时提供更全面的视角,帮助他们根据项目需求和目标市场做出更明智的决策。
|
6月前
|
Linux Android开发 iOS开发
安卓与iOS开发:平台选择对项目成功的影响
在移动应用开发的广阔舞台上,安卓与iOS两大操作系统各自占据着举足轻重的地位。本文深入探讨了这两个平台在技术特性、市场覆盖、用户群体和开发成本等方面的差异,并分析了这些差异如何影响项目的最终成功。通过比较分析,旨在为开发者提供决策依据,帮助他们根据项目需求和目标受众做出明智的平台选择。
|
7月前
|
Java 开发工具 Android开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
在移动应用开发的广阔天地中,Android和iOS两大平台各自占据着半壁江山。本文将深入探讨这两个平台在开发过程中的关键差异点,包括编程语言、开发工具、用户界面设计、性能优化以及市场覆盖等方面。通过对这些关键因素的比较分析,旨在为开发者提供一个清晰的指南,帮助他们根据项目需求和目标受众做出明智的平台选择。
|
4月前
|
IDE 开发工具 Android开发
安卓与iOS开发对比:平台选择对项目成功的影响
【9月更文挑战第10天】在移动应用开发的世界中,选择正确的平台是至关重要的。本文将深入探讨安卓和iOS这两大主要移动操作系统的开发环境,通过比较它们的市场份额、开发工具、编程语言和用户群体等方面,为开发者提供一个清晰的指南。我们将分析这两个平台的优势和劣势,并讨论如何根据项目需求和目标受众来做出最佳选择。无论你是初学者还是有经验的开发者,这篇文章都将帮助你更好地理解每个平台的特性,并指导你做出明智的决策。
|
4月前
|
Java 开发工具 Android开发
安卓与iOS开发:平台选择对项目成功的影响
在移动应用开发的浩瀚宇宙中,安卓和iOS两大星系璀璨夺目,各自拥有独特的光芒。本文将穿梭于这两个平台之间,探讨它们在开发环境、用户群体、成本效益等方面的差异,以及这些差异如何影响一个项目的航向和终点。我们将从初学者的视角出发,逐步深入,揭示选择合适平台的重要性,以及如何根据项目需求做出明智的选择。无论你是即将启航的新手开发者,还是已经在这片星海中航行的老手,这篇文章都将为你提供有价值的导航信息。
65 2
|
4月前
|
Java 开发工具 Android开发
探索安卓与iOS开发的差异:平台选择对项目的影响
在移动应用开发的广阔天地中,安卓和iOS两大平台各自占据着重要的位置。本文旨在深入探讨这两个平台在开发过程中的主要差异,包括编程语言、开发工具、用户界面设计、性能优化以及市场分布等方面。通过对比分析,我们将揭示平台选择如何影响项目规划、执行效率和最终成果,为开发者在选择适合自己项目需求的平台时提供参考依据。

相关实验场景

更多