11

非常罕见的是,我们的应用程序因为收到 SIGKILL 而崩溃。情况不同,但回溯总是相同的:

#0  0x94a00afa in mach_msg_trap ()
#1  0x94a01267 in mach_msg ()
#2  0x00fa9d5c in _UIPasteboardServerContainsTypesAtIndex ()
#3  0x00faa9ae in UIPasteboardServerContainsTypesAtIndex ()
#4  0x00fa5417 in -[UIPasteboard containsPasteboardTypes:] ()
#5  0x00de4054 in -[UITextField canPerformAction:withSender:] ()
#6  0x087038a8 in -[UIResponder(UITextAccessibilityUtilities) _accessibilityHasTextOperations] ()
#7  0x08704df5 in -[UIAccessibilityTextFieldElement _accessibilityHasTextOperations] ()
#8  0x08791dcf in -[NSObject(AXPrivCategory) accessibilityAttributeValue:] ()
#9  0x0878a3b4 in _copyMultipleAttributeValuesCallback ()
#10 0x087c5c95 in _AXXMIGCopyMultipleAttributeValues ()
#11 0x087c0a6c in _XCopyMultipleAttributeValues ()
#12 0x087c8e66 in mshMIGPerform ()
#13 0x020cf1c5 in __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ ()
#14 0x02034022 in __CFRunLoopDoSource1 ()
#15 0x0203290a in __CFRunLoopRun ()
#16 0x02031db4 in CFRunLoopRunSpecific ()
#17 0x02031ccb in CFRunLoopRunInMode ()
#18 0x02a43879 in GSEventRunModal ()
#19 0x02a4393e in GSEventRun ()
#20 0x00d2ba9b in UIApplicationMain ()
#21 0x0000284d in main (argc=1, argv=0xbfffed44) at [myapp]/main.m:14
#22 0x000027c5 in start ()

我将如何找出导致此崩溃的原因?

4

1 回答 1

1

SIGKILL 会针对任何类型的异常发送到应用程序。我们必须做出有根据的猜测,在这种情况下异常原因是什么。在上述情况下,可访问性似乎正在检查是否存在某种粘贴板类型。

由于这发生在 Apple 代码中,这很可能是 iOS 中的一个错误,因为 containsPasteboardTypes: 方法永远不应该抛出异常。仅当传递的参数为 nil 时才有可能,但错误将出现在 UIAccessibilityTextFieldElement 中,这也是 Apple 的责任。

长话短说:您需要归档雷达。作为一种解决方法,您可以在有问题的操作周围添加一个 @try 块。这将捕获并忽略异常。

于 2012-12-09T09:31:20.867 回答