iOS.Crash.OniOS8.WhenCall[popToRootViewController]
系统iOS 8.x, ARC。
CrashCase:
在UIViewController中有一个类型为UIScrollView的实例变量scrollView,
点击UIViewController中的某个按钮时调用"[self.navigationController popViewControllerAnimated:NO];",
在这之后该UIViewController的dealloc方法已被调用。在dealloc方法调用之后,scrollView其实还被系统View Tree
所持有,scrollView会访问其delegate,此时发生Crash。(UIScrollView的delegate)
在Debug时,
console会输出:"-[DSViewController respondsToSelector:]: message sent to deallocated instance 0x7ff3f6291160"
stack如图:

看第二frame: [UIScrollView _getDelegateZoomView], 执行停在line 18。
UIKit`-[UIScrollView _getDelegateZoomView]:
0x110dd48cd: pushq %rbp
0x110dd48ce: movq %rsp, %rbp
0x110dd48d1: pushq %r15
0x110dd48d3: pushq %r14
0x110dd48d5: pushq %rbx
0x110dd48d6: pushq %rax
0x110dd48d7: movq %rdi, %r14
0x110dd48da: movq 0xd344ef(%rip), %rax ; UIScrollView._zoomView
0x110dd48e1: movq (%r14,%rax), %rbx
0x110dd48e5: testq %rbx, %rbx
0x110dd48e8: jne 0x110dd497b ; -[UIScrollView _getDelegateZoomView] + 174
0x110dd48ee: movq 0xd344c3(%rip), %r15 ; UIScrollView._delegate
0x110dd48f5: movq (%r14,%r15), %rdi
0x110dd48f9: movq 0xd08228(%rip), %rdx ; "viewForZoomingInScrollView:"
0x110dd4900: movq 0xd02df9(%rip), %rsi ; "respondsToSelector:"
0x110dd4907: callq *0xac2783(%rip) ; (void *)0x00000001124b8000: objc_msgSend
0x110dd490d: xorl %ebx, %ebx
0x110dd490f: testb %al, %al
0x110dd4911: je 0x110dd497b ; -[UIScrollView _getDelegateZoomView] + 174
0x110dd4913: movq (%r14,%r15), %rdi
0x110dd4917: movq 0xd0820a(%rip), %rsi ; "viewForZoomingInScrollView:"
0x110dd491e: movq %r14, %rdx
0x110dd4921: callq *0xac2769(%rip) ; (void *)0x00000001124b8000: objc_msgSend
0x110dd4927: movq %rax, %rbx
0x110dd492a: leaq 0xd6bcdb(%rip), %rax ; _UIApplicationLinkedOnVersion
0x110dd4931: movl (%rax), %eax
0x110dd4933: testl %eax, %eax
0x110dd4935: je 0x110dd4941 ; -[UIScrollView _getDelegateZoomView] + 116
0x110dd4937: cmpl $0x4ffff, %eax
0x110dd493c: seta %al
0x110dd493f: jmp 0x110dd494b ; -[UIScrollView _getDelegateZoomView] + 126
0x110dd4941: movl $0x50000, %edi
0x110dd4946: callq 0x110d4b41f ; _UIApplicationLinkedOnOrAfter
0x110dd494b: testb %al, %al
0x110dd494d: je 0x110dd497b ; -[UIScrollView _getDelegateZoomView] + 174
0x110dd494f: cmpq %r14, %rbx
0x110dd4952: jne 0x110dd497b ; -[UIScrollView _getDelegateZoomView] + 174
0x110dd4954: movq 0xd2e5ad(%rip), %rdi ; (void *)0x00000001109c2458: NSException
0x110dd495b: movq 0xac1866(%rip), %rax ; (void *)0x000000011098aa10: NSGenericException
0x110dd4962: movq (%rax), %rdx
0x110dd4965: movq 0xd0487c(%rip), %rsi ; "raise:format:"
0x110dd496c: leaq 0xb06a3d(%rip), %rcx ; @"The view returned from viewForZoomingInScrollView: must be a subview of the scroll view. It can not be the scroll view itself."
0x110dd4973: xorl %eax, %eax
0x110dd4975: callq *0xac2715(%rip) ; (void *)0x00000001124b8000: objc_msgSend
0x110dd497b: movq %rbx, %rax
0x110dd497e: addq $0x8, %rsp
0x110dd4982: popq %rbx
0x110dd4983: popq %r14
0x110dd4985: popq %r15
0x110dd4987: popq %rbp
0x110dd4988: retq
解决方法:
在DSViewController的dealloc中将添加: "scrollView.delegate = nil;"
Q1: 在iOS 7.x中没有Crash,这是不是iOS 8.x的系统bug?
Reference
1. UIScrollView internal consistency crash
http://stackoverflow.com/questions/26103756/uiscrollview-internal-consistency-crash
2. popToRootViewController crashes when tableView is still scrolling
http://stackoverflow.com/questions/26060727/poptorootviewcontroller-crashes-when-tableview-is-still-scrolling
iOS.Crash.OniOS8.WhenCall[popToRootViewController]的更多相关文章
- iOS --------Crash 分析(一)
iOS Crash 分析(文一)- 开始 1. 名词解释 1. UUID 一个字符串,在iOS上每个可执行文件或库文件都包含至少一个UUID.目的是为了唯一识别这个文件. 2. dwarfdump 苹 ...
- iOS: Crash文件解析(一)
iOS Crash文件的解析(一) 开发程序的过程中不管我们已经如何小心,总是会在不经意间遇到程序闪退.脑补一下当你在一群人面前自信的拿着你的App做功能预演的时候,流畅的操作被无情地Crash打断. ...
- 漫谈iOS Crash收集框架
漫谈iOS Crash收集框架 Crash日志收集 为了能够第一时间发现程序问题,应用程序需要实现自己的崩溃日志收集服务,成熟的开源项目很多,如 KSCrash,plcrashreporter,C ...
- IOS Crash捕获
IOS Crash ,就两种情况:一种是异常,另一种是中断[信号量]. #include <libkern/OSAtomic.h> #include <execinfo.h> ...
- iOS Crash文件的解析
iOS Crash文件的解析 开发程序的过程中不管我们已经如何小心,总是会在不经意间遇到程序闪退.脑补一下当你在一群人面前自信的拿着你的App做功能预演的时候,流畅的操作被无情地Crash打断.联想起 ...
- iOS crash日志分析
iOS crash日志分析 一. 寻找crash文件:手机崩溃后的ips或者crash文件(ips文件可以直接修改成crash文件,直接改后缀名就可以了),这里说下如何拿到crash文件 1. 把运行 ...
- 了解和分析iOS Crash
WeTest 导读 北京时间凌晨一点,苹果一年一度的发布会如期而至.新机型的发布又会让适配相关的同学忙上一阵子啦,并且iOS Crash的问题始终伴随着移动开发者.本文将从三个阶段,由浅入深的介绍如何 ...
- iOS Crash 分析 符号化崩溃日志
参考: http://blog.csdn.net/diyagoanyhacker/article/details/41247367 http://blog.csdn.net/diyagoanyhack ...
- iOS crash 崩溃问题的追踪方法
http://www.cnblogs.com/easonoutlook/archive/2012/12/27/2835884.html iOS crash 崩溃问题的追踪方法 在调试程序的时候,总是碰 ...
随机推荐
- swift重写导航控制器类的 initialize 方法
//这个方法,是当这个类第一次被创建时调用,且只调用一次 override class func initialize() { let navBar = UINavigationBar.appeara ...
- 初识Swift中的值和引用,循坏引用、代理的注意点
1.0 在Swift中分有值类型和引用类型 Int .String . 结构体和枚举都属于值类型, 将值类型传递给方法是,将在内存中创建其副本,并传递这个副本:这样我们就可以随心所欲修改它,而不用担心 ...
- rsync sersync搭建
目标服务器 192.168.100.47 源服务器 192.168.100.46 目标服务器配置 [root@node01 nodejs]# cat /etc/rsyncd.conf #日志文件 ...
- CommonJS/AMD/CMD/UMD
为什么会有这几种模式? 起源:Javascript模块化 模块化就是把复杂问题分解成不同模块,这样可维护性高,从而达到高复用,低耦合. 1.Commonjs CommonJS是服务器端模块的规范,No ...
- centos7升级内核
载入elrepo源,搜索内核更新资源,并进行更新操作. 具体实验步骤: # 载入公钥rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org ...
- Java进阶 线程安全
多线程编程中的三个核心概念 原子性 这一点,跟数据库事务的原子性概念差不多,即一个操作(有可能包含有多个子操作)要么全部执行(生效),要么全部都不执行(都不生效). 关于原子性,一个非常经典的例子就是 ...
- js中函数的 this、arguments 、caller,call(),apply(),bind()
在函数内部有两个特殊的对象,arguments 和 this,还有一个函数对象的属性caller. arguments对象 arguments是一个类似数组的对象,包含着传入函数的所有参数. func ...
- 3. Longest Substring Without Repeating Characters (ASCII码128个,建立哈西表)
Given a string, find the length of the longest substring without repeating characters. For example, ...
- TZOJ 3209 后序遍历(已知中序前序求后序)
描述 在数据结构中,遍历是二叉树最重要的操作之一.所谓遍历(Traversal)是指沿着某条搜索路线,依次对树中每个结点均做一次且仅做一次访问. 这里给出三种遍历算法. 1.中序遍历的递归算法定义: ...
- 【校招面试 之 网络】第2题 TCP的可靠传输、流量控制、滑动窗口
1.可靠传输 (1)三次握手 TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接: (1)第一次握手:建立连接时,客户端A发送SYN包(SYN=j)到服务器B,并进入SYN_S ...