【问题标题】:Random UISearchDisplayController Crash (iOS 7)随机 UISearchDisplayController 崩溃(iOS 7)
【发布时间】:2014-02-09 20:00:20
【问题描述】:

我一直在尝试修复大约 50% 的用户遇到的崩溃问题。崩溃是在我实现 UISearchDisplayController 之后开始的(即在表格视图中添加了一个搜索栏),但我无法重现崩溃,甚至一次都没有。根据我的用户的说法,当他们打开具有 UISearchDisplayController 的表格视图时,他们会立即崩溃(或冻结)。

根据 Crashlytics 的说法,崩溃发生在:

-[UISearchDisplayController _updateTableHeaderBackgroundViewInTableView:amountScrolledUnder:]

我以编程方式创建了 UITableView,但我主要通过 IB 添加了 UISearchBar/UISearchDisplayController。

关于崩溃似乎是指的“表头背景视图”,我之前正在做两件事。首先,我将表格视图背景视图设置为 nil:

[self.tableView setBackgroundView:nil];

其次,我也是这样做的:

- (NSString *)tableView:(UITableView *)aTableView titleForHeaderInSection:(NSInteger)section
{
    if (aTableView != nil && self.searchDisplayController != nil)
    {
        if (self.searchDisplayController.isActive)
        {
            return nil;
        }
        else
        {
            return [super sectionAtIndex:section].headerTitle;
        }
    }
    else
    {
        return [super sectionAtIndex:section].headerTitle;
    }
}

从那以后,我将背景视图更改为帧大小为 CGZero 的 __strong UIView,这意味着我刚刚在背景中添加了一个强大的空视图。 此外,在第二段代码中,我现在返回一个空字符串 @"",而不是返回 nil。

我还没有将这些更改推送给我的用户,因为我想在这样做之前确定一下。试图用谷歌搜索 UISearchDisplayController 函数,但并没有真正找到任何东西,所以我猜这是 iOS 7 特有的问题,这使得追踪变得更加困难,尤其是因为我无法重现它。

无论如何,我希望有人自己遇到过这种问题,或者有人对可能导致这种情况的原因有所了解。

更新:这是完整的崩溃。

Thread : Crashed: com.apple.main-thread
0  libobjc.A.dylib                0x0000000191f179d0 objc_msgSend + 16
1  UIKit                          0x0000000188f63820 -[UISearchDisplayController _updateTableHeaderBackgroundViewInTableView:amountScrolledUnder:] + 164
2  UIKit                          0x0000000188f63394 -[UISearchBar _didMoveFromWindow:toWindow:] + 312
3  UIKit                          0x0000000188e6e42c -[UIView(Internal) _didMoveFromWindow:toWindow:] + 684
4  UIKit                          0x0000000188e9280c -[UIScrollView _didMoveFromWindow:toWindow:] + 68
5  UIKit                          0x0000000188e6dba0 __45-[UIView(Hierarchy) _postMovedFromSuperview:]_block_invoke + 148
6  UIKit                          0x0000000188e6d998 -[UIView(Hierarchy) _postMovedFromSuperview:] + 292
7  UIKit                          0x0000000188e7c4ec -[UIView(Internal) _addSubview:positioned:relativeTo:] + 1628
8  UIKit                          0x000000018906af44 -[_UIParallaxDimmingView didMoveToWindow] + 144
9  UIKit                          0x0000000188e6e768 -[UIView(Internal) _didMoveFromWindow:toWindow:] + 1512
10 UIKit                          0x0000000188e6e42c -[UIView(Internal) _didMoveFromWindow:toWindow:] + 684
11 UIKit                          0x0000000188e6dba0 __45-[UIView(Hierarchy) _postMovedFromSuperview:]_block_invoke + 148
12 UIKit                          0x0000000188e6d998 -[UIView(Hierarchy) _postMovedFromSuperview:] + 292
13 UIKit                          0x0000000188e7c4ec -[UIView(Internal) _addSubview:positioned:relativeTo:] + 1628
14 UIKit                          0x000000018906a67c __53-[_UINavigationParallaxTransition animateTransition:]_block_invoke + 1636
15 UIKit                          0x0000000188e82bb8 +[UIView(Animation) performWithoutAnimation:] + 88
16 UIKit                          0x0000000189069d54 -[_UINavigationParallaxTransition animateTransition:] + 828
17 UIKit                          0x0000000189022078 -[UINavigationController _startCustomTransition:] + 2724
18 UIKit                          0x0000000188f2c794 -[UINavigationController _startDeferredTransitionIfNeeded:] + 464
19 UIKit                          0x0000000188f2c564 -[UINavigationController __viewWillLayoutSubviews] + 56
20 UIKit                          0x0000000188f2c4e4 -[UILayoutContainerView layoutSubviews] + 200
21 UIKit                          0x0000000188e6ed78 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 348
22 QuartzCore                     0x0000000188a6b0cc -[CALayer layoutSublayers] + 184
23 QuartzCore                     0x0000000188a65c94 CA::Layer::layout_if_needed(CA::Transaction*) + 300
24 QuartzCore                     0x0000000188a65b4c CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 32
25 QuartzCore                     0x0000000188a653d4 CA::Context::commit_transaction(CA::Transaction*) + 280
26 QuartzCore                     0x0000000188a65178 CA::Transaction::commit() + 424
27 QuartzCore                     0x0000000188a5ea30 CA::Transaction::observer_callback(__CFRunLoopObserver*, unsigned long, void*) + 80
28 CoreFoundation                 0x0000000185f5f7e0 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 32
29 CoreFoundation                 0x0000000185f5ca68 __CFRunLoopDoObservers + 372
30 CoreFoundation                 0x0000000185f5cdf4 __CFRunLoopRun + 764
31 CoreFoundation                 0x0000000185e9db38 CFRunLoopRunSpecific + 452
32 GraphicsServices               0x000000018b8c3830 GSEventRunModal + 168
33 UIKit                          0x0000000188edc0e8 UIApplicationMain + 1156
34 Flash Reader                   0x00000001000904dc main + 17 (main.m:17)
35 libdyld.dylib                  0x0000000192507aa0 start + 4

更新 2: 这似乎只发生在 iPhone 5S 上,这也可以解释为什么我无法重现这一点。我感觉和这段代码有关:

CGRect newBounds = self.tableView.bounds;
    if (self.tableView.bounds.origin.y < 44)
    {
        newBounds.origin.y = newBounds.origin.y + self.searchDisplayController.searchBar.bounds.size.height;
        self.tableView.bounds = newBounds;
    }
    // new for iOS 7
    if (self.tableView != nil && self.staticContentSections.count > 0)
    {
        [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForItem:0 inSection:0] atScrollPosition:0 animated:YES];
    }

我希望这是导致崩溃的原因,因为如果是这样,我希望通过在 viewWillAppear 中执行此操作来解决此问题:

self.edgesForExtendedLayout = UIRectEdgeNone;
self.tableView.contentOffset = CGPointMake(0, 44);

更新 3: 好吧,那并没有解决它。这种情况仍然会发生,无论是随机发生还是每次用户拥有 iPhone 5S 时都会发生。它不会在 5S 模拟器中发生,但我无法进一步调试它,因为我没有 5S。我开始认为这是 iOS 7 的错误,而不是应用程序本身的错误。

【问题讨论】:

  • 您需要尝试重现它并获得更好的堆栈跟踪 - 否则这是一个猜测 :) 随机冻结听起来像是内存问题 - 您是否尝试分析应用程序,使用分析器?尤其是打开搜索视图的那一刻?
  • 随机,我的意思是,据我所知,它发生在随机用户身上。我还可以从 Crashlytics 看到这些用户有足够的内存/应用程序没有使用太多内存,所以我不完全确定这是内存问题。不过,我将继续分析该应用程序。我用堆栈跟踪更新了原始帖子。

标签: ios uitableview ios7 uisearchbar uisearchdisplaycontroller


【解决方案1】:

我在 iOS 8.0 中遇到了崩溃。我通过在视图控制器的 dealloc (deinit) 中设置 searchBar.delegate = nil 来修复它。

【讨论】:

  • 你也在使用ARC吗?
猜你喜欢
  • 2011-12-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-05-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多