0

我有几个方法可以做几乎相同的事情,唯一的区别是它们使用的选择器,它被作为参数传递。但是选择器使用不同数量的参数,从 0 到 2,它们也作为参数传递。它看起来像这样(SupportClass 是一个类,我从中调用一个要在随机方法中使用的方法):

-(void) RandomMethod: (SEL) selector {
// some actions here
[SupportClass performSelector:selector];
}

-(void) RandomMethod2: (SEL) selector withObject: object {
// the same actions here
[SupportClass performSelector:selector withObject: object];
}

-(void) RandomMethod2: (SEL) selector withObject1: object1 withObject2: object2 {
// again - the same actions
[SupportClass performSelector:selector withObject1: object1 withObject2:object2];
}

但是由于它们都做同样的事情,我想找到一个更通用的解决方案,可以将它压缩成一个方法,这也可以让我将它用于具有更多参数的选择器(我很可能不需要,但是我仍然认为它看起来不错)。有谁知道如何做到这一点,并愿意告诉我?

4

3 回答 3

2

不是传递选择器+参数,而是传递代码块。您的代码似乎是完成块的完美示例。

例子:

- (void)someMethodWithCompletionBlock:(void(^)())completionBlock {
   //do something
   completionBlock();
}

[myObject someMethodWithCompletionBlock:^{
    [SupportClass performSelector:selector];
};
于 2013-09-05T09:30:49.640 回答
0

块是最好的方法。

另一种通用解决方案是使用forwardInvocation:. 不是实现这些方法,而是forwardInvocation:在某个代理对象上实现,然后调用者调用他们想在这个代理对象上正常调用的方法(即他们没有分离出选择器等。他们假装这个对象有这些方法并使用参数调用该方法。)。然后在 中forwardInvocation:,它可以调用对 的调用SupportClass

于 2013-09-06T03:06:44.230 回答
0

块解决方案似乎最好,

您还可以修改您的方法以仅接收 NSDictionary 作为唯一参数,并使用此 NSDictionary 传递您的数据

  • (void)methodA:(NSDictionary *)data;

  • (void)methodB:(NSDictionary *)data;

于 2013-09-05T09:35:17.400 回答