1

开发的应用程序在 Xcode 模拟器上运行良好,但是当我在真实设备上测试它时被终止。以下是应用程序终止时我的手机控制台打印的内容。

Nov 22 00:51:09 iPhone ReportCrash[3862] <Notice>: Formulating crash report for process CoL[3860]
��Nov 22 00:51:09 iPhone ReportCrash[3862] <Error>: libMobileGestalt copySystemVersionDictionaryValue: Could not lookup ReleaseType from system version dictionary
��Nov 22 00:51:09 iPhone com.apple.launchd[1] (UIKitApplication:pan.ConquestOfLancaster[0xd857][3860]) <Warning>: (UIKitApplication:pan.ConquestOfLancaster[0xd857]) Job appears to have crashed: Segmentation fault: 11
��Nov 22 00:51:09 iPhone backboardd[52] <Warning>: Application 'UIKitApplication:pan.ConquestOfLancaster[0xd857]' exited abnormally with signal 11: Segmentation fault: 11
��Nov 22 00:51:09 iPhone ReportCrash[3862] <Notice>: Saved crashreport to /var/mobile/Library/Logs/CrashReporter/CoL_2012-11-22-005109_iPhone.plist using uid: 0 gid: 0, synthetic_euid: 501 egid: 0
��Nov 22 00:51:09 iPhone awdd[3863] <Error>: libMobileGestalt copySystemVersionDictionaryValue: Could not lookup ReleaseType from system version dictionary

基本上,当我触发 NSTimer(倒计时)并达到“1”时,就会出现问题。冻结一段时间然后终止。

这是定时器初始化的方法:

- (void)MapMenu:(MapMenu *)menu didSelectButton:(NSInteger)index{

    if (index == 0) {
        if (self.owner == nil && distance < 10) {
            CountDownTimer* countDown = [[CountDownTimer alloc]init];
            [countDown startTimerOn:parentView];
            [self performSelector:@selector(attackTo:attacker:) withObject:nil afterDelay:20.0];
        }
        else if (self.owner == @"Player_1")
            NSLog(@"You have already occupy this building with name, %@", self.title);
    }
}

- (void) attackTo: (BuildingViewController*) selectedBuilding attacker: (NSString*) attacker{

    self.owner = @"Player_1";
    NSLog(@"Building has a new owner with name, %@", self.owner);
}

有没有人有这方面的线索。真的……输了!

提前致谢

4

2 回答 2

2

我不确定这是否是崩溃的根源,但是您确实在这里遇到了问题:

[self performSelector:@selector(attackTo:attacker:) withObject:nil afterDelay:20.0];

基本上,选择器调用有两个事实:意味着它需要两个参数。如果使用 method performSelector:withObject:afterDelay:,则只能将其与具有一个参数的方法一起使用。

例如,

[self performSelector:@selector(doSomething:) withObject:object afterDelay:20.0f]

相当于

[self doSomething:object]

大约 20 秒后执行。

在这种情况下,你有一个不匹配,因为你@selector两个参数,所以你不能用那个特定的performSelector方法使用它。

虽然有一个performSelector:withObject:withObject方法需要两个参数,但它没有delay参数。您可能需要改为使用NSInvocation,或更改attackTo:attacker:它以使其使用单个参数(例如,NSDictionary)。

于 2012-11-22T01:25:26.310 回答
0

我看到您使用了一个名为 CountDownTimer 的类。这是 NSTimer 的子类吗?如果是这样,您应该阅读 NSTimer 类参考中的子类化注释。 NSTimer 类参考

基本上,它说不要这样做。实际上甚至基本上没有,它说不要这样做。

在阅读类参考时,请查看如何在 n 秒后实现回调。就个人而言,我喜欢+ scheduledTimerWithTimeInterval:target:selector:userInfo:repeats:

于 2012-11-22T01:15:31.367 回答