iPhone:从app delegate crashes app无效NSTimer

时间:2010-09-12 02:45:41

标签: iphone delegates crash nstimer uiapplicationdelegate

我正在尝试从我的app委托中运行一个方法,该方法将对象保存在其他类中,并使计时器无效。我已将其设置为当我的应用程序退出时,它会在我的班级中运行该方法并保存并停止计时器。

在app delegate:

- (void)applicationWillResignActive:(UIApplication *)application {

    // Save the mission because they are leaving the app
    if ([timeRun hasScore]) {
        [timeRun resetWithSave];
    }

}

它在“timeRun”类中调用的方法:

- (void)resetWithSave {
    // Save
    self.counterInt = 150;
    self.timer.text = [self timeInSeconds:counterInt];
    [start setBackgroundImage:[UIImage imageNamed:@"play.png"] forState:UIControlStateNormal];
    self.started = NO;
    self.score.text = @"0";
    [self saveMission];
    if ([countTimer isValid]) {
        [countTimer invalidate];
    }
    [table scrollRectToVisible:CGRectMake(0, 0, 1, 1) animated:NO];
}

但是,我正在崩溃:

2010-09-11 19:35:21.503 Score Card[2747:307] -[__NSCFType isValid]: unrecognized selector sent to instance 0x19e190
2010-09-11 19:35:21.594 Score Card[2747:307] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFType isValid]: unrecognized selector sent to instance 0x19e190'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x30897ed3 __exceptionPreprocess + 114
    1   libobjc.A.dylib                     0x3002f811 objc_exception_throw + 24
    2   CoreFoundation                      0x30899683 -[NSObject(NSObject) doesNotRecognizeSelector:] + 102
    3   CoreFoundation                      0x308411d9 ___forwarding___ + 508
    4   CoreFoundation                      0x30840f90 _CF_forwarding_prep_0 + 48
    5   Score Card                          0x00006b3d -[TimeRun resetWithSave] + 272
    6   Score Card                          0x00002b39 -[Score_CardAppDelegate applicationWillResignActive:] + 80
    7   UIKit                               0x31ea6879 -[UIApplication _setActivated:] + 212
    8   UIKit                               0x31eda4ab -[UIApplication _handleApplicationSuspend:eventInfo:] + 238
    9   UIKit                               0x31eab301 -[UIApplication handleEvent:withNewEvent:] + 2200
    10  UIKit                               0x31eaa901 -[UIApplication sendEvent:] + 44
    11  UIKit                               0x31eaa337 _UIApplicationHandleEvent + 5110
    12  GraphicsServices                    0x31e4504b PurpleEventCallback + 666
    13  CoreFoundation                      0x3082cce3 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 26
    14  CoreFoundation                      0x3082cca7 __CFRunLoopDoSource1 + 166
    15  CoreFoundation                      0x3081f56d __CFRunLoopRun + 520
    16  CoreFoundation                      0x3081f277 CFRunLoopRunSpecific + 230
    17  CoreFoundation                      0x3081f17f CFRunLoopRunInMode + 58
    18  GraphicsServices                    0x31e445f3 GSEventRunModal + 114
    19  GraphicsServices                    0x31e4469f GSEventRun + 62
    20  UIKit                               0x31e51123 -[UIApplication _run] + 402
    21  UIKit                               0x31e4f12f UIApplicationMain + 670
    22  Score Card                          0x000029ef main + 70
    23  Score Card                          0x000029a4 start + 40
)
terminate called after throwing an instance of 'NSException'
Program received signal:  “SIGABRT”.
kill
quit

为什么这会让我的应用程序崩溃?

2 个答案:

答案 0 :(得分:5)

预感到,你正在做类似

的事情
countTimer = [NSTimer scheduledTimerWithTarget:...];

...

if ([countTimer isValid])
{
  [countTimer invalidate];
}

...


if ([countTimer isValid])
{
  [countTimer invalidate];
}

“预定”计时器会为您添加到运行循环中。然后由运行循环保留。使其无效将其从运行循环中删除,因此它被释放。如果没有其他东西保留它,它将被解除分配。当你再次尝试使用它时,它会崩溃。

尝试[countTimer invalidate]; countTimer = nil;

之类的内容

或者,您可以保留计时器,但请注意计时器会保留其目标,因此很容易以保留周期结束。

答案 1 :(得分:0)

看起来计时器从未被初始化或被释放。有时像这样的异常会随机对象抛出,当它也是零时。检查指针并保留计数!