2

在 xcode 上工作时,我意识到如果我创建了一个非 void 方法,我从一个类/方法中调用它,那么只有当动作是即时的时,结果才会得到最佳处理。我试图通过插入延迟来进行测试,但我意识到它不再有效。我将在这里写下我创建的示例:

A级

//--------------------CLASS A
- (void)viewDidLoad {
   [super viewDidLoad];
   i = 0;
   Class *classB = [[Class alloc] init];
   i = [classB method1];
   [self performSelector:@selector(method3) withObject:NULL afterDelay:1.8];
}

-(void)method3 {
   NSLog(@"i = %i",i); // i = 0
}

B类

//--------------------CLASS B    
-(int)method1 {
  [self performSelector:@selector(method2) withObject:NULL afterDelay:1];
  return a;
}

-(void)method2 {
  a = 800;
}

显然我的问题不是那么微不足道,但我试图尽可能彻底地得到答案,我被建议使用模态方法,但我认为这不是我正在寻找的解决方案。

我能做些什么来解决这个问题?!

4

2 回答 2

2

我能做些什么来解决这个问题?!

您要将值返回哪里?在您的示例中,method1将在很久之前完成method2。如果您想保留由 计算的值method2,您通常会让该方法将该值存储在 ClassB 的一个实例变量中,并可能调用其他一些方法来继续处理。

如果您确实需要method1从 中返回结果method2,则需要同步调用它(即不使用-performSelector:withObject:afterDelay:)。在这种情况下,请考虑 a) 为什么需要延迟;b)如果您应该method1在延迟而不是method2.

如果您能解释您要解决的实际问题是什么,我们将能够提供更好的帮助。

于 2012-05-26T15:42:20.830 回答
2

您真正需要的是更好地理解异步方法。在您method1的变量a中,变量永远不会改变——您所做的只是安排method2将来调用,然后返回变量的当前状态a

在 Objective-C 中,有几种不同的方法可以解决这个问题。人们最常使用protocolsdelegates来解决这个问题。这是协议和委托的基本介绍。基本上,您会希望您的 A 类对象成为 B 类对象的委托。您也可以使用NSNotificationsblocks,尽管在继续使用通知和块之前,您可能应该了解协议和委托的用法(它们在 Objective-C 中非常重要)。

于 2012-05-26T15:46:48.780 回答