与[UITextField _textNeedsSanitizing:]相关的崩溃问题

时间:2015-07-24 10:52:10

标签: objective-c ios8 crash-reports hockeyapp

我的ios8应用程序崩溃,提供以下日志

Incident Identifier:
CrashReporter Key:  
Hardware Model:      iPhone7,2
Process:         APP Beta [3203]
Path:            /private/var/mobile/Containers/Bundle/Application/B471AC73-68B1-425B-/APP Beta.app/APP Beta
Identifier:      com.product.APP
Version:         2.0.34
Code Type:       ARM-64
Parent Process:  launchd [1]

Date/Time:       2015-07-20T22:21:19Z
OS Version:      iPhone OS 8.4 (1243)
Report Version:  104

Exception Type:  SIGABRT
Exception Codes: #0 at 0x196d23270
Crashed Thread:  0

Application Specific Information:
*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSArrayM rangeOfCharacterFromSet:]: unrecognized selector sent to instance 0x17045d2e0'

Last Exception Backtrace:
0   CoreFoundation                       0x00000001848942d8 <redacted> + 132
1   libobjc.A.dylib                      0x00000001965600e4 objc_exception_throw + 60
2   CoreFoundation                       0x000000018489b3a4 <redacted> + 0
3   CoreFoundation                       0x0000000184898154 <redacted> + 928
4   CoreFoundation                       0x000000018479accc _CF_forwarding_prep_0 + 92
5   UIKit                                0x0000000189a60a24 -[UITextField _textNeedsSanitizing:] + 148
6   UIKit                                0x000000018934a114 -[UITextField setText:] + 56
7   APP Beta                             0x00000001001c13b4 -[APPEditCardInformation initWithFrame:] + 1384
8   APP Beta                             0x0000000100182a60 -[APPEditViewController drawPrimaryView] + 568
9   APP Beta                             0x0000000100181234 -[APPEditViewController viewDidLoad] + 432
10  UIKit                                0x000000018930cc18 -[UIViewController loadViewIfRequired] + 692
11  UIKit                                0x000000018930c928 -[UIViewController view] + 32
12  UIKit                                0x00000001894af1f0 -[UINavigationController _startCustomTransition:] + 712
13  UIKit                                0x00000001893c1e84 -[UINavigationController _startDeferredTransitionIfNeeded:] + 468
14  UIKit                                0x00000001893c1c50 -[UINavigationController __viewWillLayoutSubviews] + 56
15  UIKit                                0x00000001893c1bd0 -[UILayoutContainerView layoutSubviews] + 200
16  UIKit                                0x00000001893096f4 -[UIView layoutSublayersOfLayer:] + 580
17  QuartzCore                           0x0000000188c45db8 -[CALayer layoutSublayers] + 152
18  QuartzCore                           0x0000000188c40820 <redacted> + 320
19  QuartzCore                           0x0000000188c406c4 <redacted> + 32
20  QuartzCore                           0x0000000188c3fe58 <redacted> + 276
21  QuartzCore                           0x0000000188c3fbd8 <redacted> + 528
22  QuartzCore                           0x0000000188c39300 <redacted> + 80
23  CoreFoundation                       0x000000018484c2a4 <redacted> + 32
24  CoreFoundation                       0x0000000184849230 <redacted> + 360
25  CoreFoundation                       0x0000000184849610 <redacted> + 836
26  CoreFoundation                       0x00000001847752d4 CFRunLoopRunSpecific + 396
27  GraphicsServices                     0x000000018e1cb6fc GSEventRunModal + 168
28  UIKit                                0x0000000189372f40 UIApplicationMain + 1488
29  APP Beta                             0x0000000100190bf4 -[NSInvocation mp_returnValue] + 23644
30  libdyld.dylib                        0x0000000196c0aa08 <redacted> + 4

Thread 0 Crashed:
0   libsystem_kernel.dylib               0x0000000196d23270 __pthread_kill + 8
1   libsystem_c.dylib                    0x0000000196c9ab18 abort + 112
2   APP Beta                             0x000000010067b9e0 -[FlurryPLCrashReporter generateLiveReportWithThread:] + 0
3   CoreFoundation                       0x0000000184894698 <redacted> + 692
4   libobjc.A.dylib                      0x00000001965603b4 <redacted> + 116
5   libc++abi.dylib                      0x0000000195d49bb4 <redacted> + 16
6   libc++abi.dylib                      0x0000000195d49478 <redacted> + 0
7   libobjc.A.dylib                      0x0000000196560204 <redacted> + 0
8   CoreFoundation                       0x000000018489b3a4 <redacted> + 0
9   CoreFoundation                       0x0000000184898154 <redacted> + 928
10  CoreFoundation                       0x000000018479accc _CF_forwarding_prep_0 + 92
11  UIKit                                0x0000000189a60a24 -[UITextField _textNeedsSanitizing:] + 148
12  UIKit                                0x000000018934a114 -[UITextField setText:] + 56
13  APP Beta                             0x00000001001c13b4 -[APPEditCardInformation initWithFrame:] + 1384
14  APP Beta                             0x0000000100182a60 -[APPEditViewController drawPrimaryView] + 568
15  APP Beta                             0x0000000100181234 -[APPEditViewController viewDidLoad] + 432
16  UIKit                                0x000000018930cc18 -[UIViewController loadViewIfRequired] + 692
17  UIKit                                0x000000018930c928 -[UIViewController view] + 32
18  UIKit                                0x00000001894af1f0 -[UINavigationController _startCustomTransition:] + 712
19  UIKit                                0x00000001893c1e84 -[UINavigationController _startDeferredTransitionIfNeeded:] + 468
20  UIKit                                0x00000001893c1c50 -[UINavigationController __viewWillLayoutSubviews] + 56
21  UIKit                                0x00000001893c1bd0 -[UILayoutContainerView layoutSubviews] + 200
22  UIKit                                0x00000001893096f4 -[UIView layoutSublayersOfLayer:] + 580
23  QuartzCore                           0x0000000188c45db8 -[CALayer layoutSublayers] + 152
24  QuartzCore                           0x0000000188c40820 <redacted> + 320
25  QuartzCore                           0x0000000188c406c4 <redacted> + 32
26  QuartzCore                           0x0000000188c3fe58 <redacted> + 276
27  QuartzCore                           0x0000000188c3fbd8 <redacted> + 528
28  QuartzCore                           0x0000000188c39300 <redacted> + 80
29  CoreFoundation                       0x000000018484c2a4 <redacted> + 32
30  CoreFoundation                       0x0000000184849230 <redacted> + 360
31  CoreFoundation                       0x0000000184849610 <redacted> + 836
32  CoreFoundation                       0x00000001847752d4 CFRunLoopRunSpecific + 396
33  GraphicsServices                     0x000000018e1cb6fc GSEventRunModal + 168
34  UIKit                                0x0000000189372f40 UIApplicationMain + 1488
35  APP Beta                             0x0000000100190bf4 -[NSInvocation mp_returnValue] + 23644
36  libdyld.dylib                        0x0000000196c0aa08 <redacted> + 4

有人对此问题有任何想法吗?

这是我在viewWillAppear

中调用的函数
- (void)updateEditView {
    if (IS_IPAD) {
        float height = 0;
        float width = 0;
        if (INTERFACE_IS_PHONE || [[UIScreen mainScreen] bounds].size.height == 480) {
            height = HEIGHT;
            width = WIDTH;
        }
        else {
            if( [[UIApplication sharedApplication] statusBarOrientation] == UIInterfaceOrientationLandscapeLeft || [[UIApplication sharedApplication] statusBarOrientation] ==  UIInterfaceOrientationLandscapeRight) {
                if (IS_OS_8_OR_LATER) {
                    height = HEIGHT;
                    width = WIDTH;
                }
                else {
                    height = WIDTH;
                    width = HEIGHT;
                }
            }
            else {
                height = HEIGHT;
                width = WIDTH;
            }

        }
        navigationBar.frame = CGRectMake(navigationBar.frame.origin.x,    navigationBar.frame.origin.y, width, navigationBar.frame.size.height);

        titleLabel.frame = CGRectMake(50, 21, width - 100, 45);
        if (innerView == 1) {
            editAddress.frame = CGRectMake(0, 0, width, height);
            editAddress.userFullName.frame = CGRectMake(editAddress.userFullName.frame.origin.x, editAddress.userFullName.frame.origin.y, width - (2*editAddress.userFullName.frame.origin.x), editAddress.userFullName.frame.size.height);
            editAddress.streetAddress.frame = CGRectMake(editAddress.streetAddress.frame.origin.x, editAddress.streetAddress.frame.origin.y, width - (2*editAddress.streetAddress.frame.origin.x), editAddress.streetAddress.frame.size.height);
            editAddress.zipCode.frame = CGRectMake(editAddress.zipCode.frame.origin.x, editAddress.zipCode.frame.origin.y, width - (2*editAddress.zipCode.frame.origin.x), editAddress.zipCode.frame.size.height);
            editAddress.cityField.frame = CGRectMake(editAddress.cityField.frame.origin.x, editAddress.cityField.frame.origin.y, width/2 - (2*editAddress.cityField.frame.origin.x), editAddress.cityField.frame.size.height);
            editAddress.stateField.frame = CGRectMake(width/2 + 20, editAddress.stateField.frame.origin.y, width/2 - (2*20), editAddress.stateField.frame.size.height);
            editAddress.onlySeperator.frame = CGRectMake(width/2.0, 66 + 180, 1, 60);

            if ([[UIApplication sharedApplication] statusBarOrientation] == UIInterfaceOrientationLandscapeLeft || [[UIApplication sharedApplication] statusBarOrientation] ==  UIInterfaceOrientationLandscapeRight) {
                editAddress.saveButton.frame = CGRectMake(140, editAddress.saveButton.frame.origin.y, width - 2*140, editAddress.saveButton.frame.size.height);
            }
            else
                editAddress.saveButton.frame = CGRectMake(10, editAddress.saveButton.frame.origin.y, width - 20, editAddress.saveButton.frame.size.height);

        }
        else if (innerView == 2) {
            editCardInfo.frame = CGRectMake(0, 0, width, height);
            editCardInfo.onlySeperator.frame = CGRectMake(width/2.0, 66 + 120, 1, 60);

            editCardInfo.nameOnCard.frame = CGRectMake(editCardInfo.nameOnCard.frame.origin.x, editCardInfo.nameOnCard.frame.origin.y, width - (2*editCardInfo.nameOnCard.frame.origin.x), editCardInfo.nameOnCard.frame.size.height);
            editCardInfo.creditCardNumber.frame = CGRectMake(editCardInfo.creditCardNumber.frame.origin.x, editCardInfo.creditCardNumber.frame.origin.y, width - (2*editCardInfo.creditCardNumber.frame.origin.x), editCardInfo.creditCardNumber.frame.size.height);
            editCardInfo.expireDate.frame = CGRectMake(editCardInfo.expireDate.frame.origin.x, editCardInfo.expireDate.frame.origin.y, width/2 - (2*editCardInfo.expireDate.frame.origin.x), editCardInfo.expireDate.frame.size.height);
            editCardInfo.cvcNumber.frame = CGRectMake(width/2 + 20, editCardInfo.cvcNumber.frame.origin.y, width/2 - (2*20), editCardInfo.cvcNumber.frame.size.height);

            editCardInfo.creditCardImage.frame = CGRectMake(width - 20 - 33, editCardInfo.creditCardImage.frame.origin.y, editCardInfo.creditCardImage.frame.size.width, editCardInfo.creditCardImage.frame.size.height);

            if ([[UIApplication sharedApplication] statusBarOrientation] == UIInterfaceOrientationLandscapeLeft || [[UIApplication sharedApplication] statusBarOrientation] ==  UIInterfaceOrientationLandscapeRight) {
                editCardInfo.saveButton.frame = CGRectMake(140, editCardInfo.saveButton.frame.origin.y, width - 2*140, editCardInfo.saveButton.frame.size.height);
            }
            else
                editCardInfo.saveButton.frame = CGRectMake(10, editCardInfo.saveButton.frame.origin.y, width - 20, editCardInfo.saveButton.frame.size.height);

        }
        else if (innerView == 3) {

            editContactInfo.frame = CGRectMake(0, 0, width, height);

            editContactInfo.emailAddressField.frame = CGRectMake(editContactInfo.emailAddressField.frame.origin.x, editContactInfo.emailAddressField.frame.origin.y, width - 2*editContactInfo.emailAddressField.frame.origin.x, editContactInfo.emailAddressField.frame.size.height);

            editContactInfo.contactNumberField.frame = CGRectMake(editContactInfo.contactNumberField.frame.origin.x, editContactInfo.contactNumberField.frame.origin.y, width - 2*editContactInfo.contactNumberField.frame.origin.x, editContactInfo.contactNumberField.frame.size.height);

            if ([[UIApplication sharedApplication] statusBarOrientation] == UIInterfaceOrientationLandscapeLeft || [[UIApplication sharedApplication] statusBarOrientation] ==  UIInterfaceOrientationLandscapeRight) {
                editContactInfo.saveButton.frame = CGRectMake(140, editContactInfo.saveButton.frame.origin.y, width - 2*140, editContactInfo.saveButton.frame.size.height);
            }
            else
                editContactInfo.saveButton.frame = CGRectMake(10, editContactInfo.saveButton.frame.origin.y, width - 20, editContactInfo.saveButton.frame.size.height);
        }
    }
}

用户从后台打开应用时会出现此问题。

1 个答案:

答案 0 :(得分:1)

tl; dr 这是一个内存问题,该字符串不再有效。

您可以使用以下步骤/代码简单地重现堆栈跟踪:

// 1) create a property to enforce the memory issue
@property (nonatomic, assign) NSString* dumpString

现在我们只是稍微欺骗编译器......

// 2) create an invalid "string"object, in this case, a view :)
NSDictionary* dict = @{@"key": [[UIView alloc] init]};
// 3) because objectForKey: will return an id, the runtime has no idea that it is no string
self.dumpString = [dict objectForKey:@"key"];
// 4) here is your crash, when we set the value to the textfield, the textfield tries to sanitize the string and runs into an invalid memory layout
self.textField.text = self.dumpString;