ios – 在Objective C中使用静态init时的优点?

前端之家收集整理的这篇文章主要介绍了ios – 在Objective C中使用静态init时的优点?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
最近我发现了 webrtc-ios example from Github.虽然我正在浏览项目,我注意到VideoView类使用静态方法,我不知道这是否需要.
VideoView是UIView的子类,它覆盖了两个init方法initWithFrame:initWithCoder:.我知道覆盖那些init方法是正常的,然后使用一些方法来设置其他的东西,如 – (void)setup;

但VideoView类使用静态函数,static void init(VideoView * self).问题是使用静态函数与正常ObjC方法有什么好处?

VideoView类中的代码如下所示:

-(id)initWithFrame:(CGRect)frame {

     if (self = [super initWithFrame:frame]) {
         init(self);
     }
     return self; 
}

-(id)initWithCoder:(NSCoder *)aDecoder {

     if (self = [super initWithCoder:aDecoder]) {
         init(self);
     }
     return self; 
}

 static void init(VideoView *self) { ... }

解决方法

使用静态函数和Objective-C方法的一个区别是
静态函数不能在子类中覆盖.如果共同的init代码完成
在一个
- (void)setup;

方法和VideoView的子类MyVideoView恰好实现了一个名称相同的方法

[[MyVideoView alloc] initWithFrame:..]

调用子类实现,这可能不需要.

在你的代码中,
initWithFrame / initWithCoder将始终调用本地的init()函数,即使这样
一个子类的实例被初始化.

如果常用的初始化在一个方法中完成,那么方法名称应该更多
具体来说,以避免它被“意外地”覆盖

-(void)commonVideoViewSetup;

猜你在找的iOS相关文章