记一例UIView突然不显示的排查过程

一、现象

  今日在开发中遇到一个诡异问题,一个自定义的AlertView在显示之后瞬间在屏幕上消失,但是其对象在内存中依然存在

 

二、排查

  通过lldb命令查询到view.superview.superview不存在为nil,才明白这个view的父view的父view被释放掉了,释放过程中该view自动从屏幕中移除导致。

  该问题排查花费一个多小时。

 

三、总结UIView不显示的思路

  • 判断这个view的大小是否为CGRectZero,这个view的位置是否超出父view。autolayout布局错误等
  • 判断这个view的透明度信息是否为0,这个view的hidden是否为yes。
  • 如果上面的信息正常,依次递归父view的上述信息是否正常。
  • 查看界面是否未刷新,是否在子线程刷新了界面

  如果发现异常,但是未能定位到view被隐藏的调用逻辑

  1)在常规的隐藏,hidden,alpha处下断点

  2)在removeFromSuperview处下断点

  3)针对异常的对象下内存访问断点

  4)针对异常的view,将其继承自定义view,重载特殊方法,在该方法中下断点

  

@implementation DebugView

- (void)didMoveToWindow
{
    if(self.window == nil)
    {
//        NSLog(@"visiable");
    }
    else
    {
//        NSLog(@"invisiable");
    }
}

- (void)didMoveToSuperview
{
    if(self.superview == nil)
    {
//        NSLog(@"visiable");
    }
    else
    {
//        NSLog(@"invisiable");
    }
}

@end

  

posted @ 2018-09-04 17:24  兜兜有糖的博客  阅读(794)  评论(0编辑  收藏  举报