Objective-C的Initialize初始化方法研究

来源:互联网 发布:日德兰海战知乎 编辑:程序博客网 时间:2024/05/16 11:56

initialize不是init

 运行时间的行为之一就是initialize。虽然看起来有点像大家常见的init,但是他们并不相同。

 举个例子,比如一个叫做Duck的类:

  1. #import "Duck.h";
  2.  
  3. @implementation Duck
  4.  
  5. +(void) initialize {
  6.         NSLog(@"Duck initialize");
  7. }
  8.  
  9. -(void) init {
  10.         NSLog(@"Duck init");
  11. }
  12. @end

 我们在这里记录initialize和init调用的时间。

[Session started at 2008-03-23 20:03:25 -0400.]

2008-03-23 20:03:25.869 initialize_example[30253:10b] Hello, World!

2008-03-23 20:03:25.871 initialize_example[30253:10b] Duck initialize

2008-03-23 20:03:25.872 initialize_example[30253:10b] Duck init

2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init

2008-03-23 20:03:25.873 initialize_example[30253:10b] Duck init

但是如果Duck有一个子类的话,比如我们建一个Duck的子类叫做Chicken(好怪异……):

  1. NSLog(@"Hello, World!");
  2.        
  3.         Duck* duck1 = [[Duck alloc] init];
  4.         Duck* duck2 = [[Duck alloc] init];
  5.         Duck* duck3 = [[Duck alloc] init];
  6.        
  7.         Chicken* chicken = [[Chicken alloc] init];
  8. }

[Session started at 2008-03-23 20:13:34 -0400.]

2008-03-23 20:13:34.696 initialize_example[30408:10b] Hello, World!

2008-03-23 20:13:34.698 initialize_example[30408:10b] Duck initialize

2008-03-23 20:13:34.699 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck init

2008-03-23 20:13:34.700 initialize_example[30408:10b] Duck initialize

2008-03-23 20:13:34.701 initialize_example[30408:10b] Duck init

 看来如果一个子类没有实现initialize方法,那么超类会调用这个方法两次,一次为自己,而一次为子类。 

[Session started at 2008-03-23 20:21:08 -0400.]

2008-03-23 20:21:08.816 initialize_example[30513:10b] Hello, World!

2008-03-23 20:21:08.818 initialize_example[30513:10b] Duck initialize class:Duck

2008-03-23 20:21:08.819 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck init

2008-03-23 20:21:08.820 initialize_example[30513:10b] Duck initialize class:Chicken

2008-03-23 20:21:08.821 initialize_example[30513:10b] Duck init

如果你希望确定只用了initialize一次用来实现某些单独运行的工作,或者希望实现仅仅运行一次的方法,检查一下[self class],才能确定是否是你希望做到的效果。
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 苏宁订单删除了怎么办 联通销户话费有余额怎么办 暖气改地热不热怎么办 老楼房暖气不热怎么办 4s店修不好车怎么办 苏宁的发票丢了怎么办 京东退货没有发票怎么办 发票发错了邮箱怎么办 苹果手机忘记电子邮箱验证码怎么办 退差价把红包退还了怎么办 网上购票票丢了怎么办 岗位人手不够老板又不招人来怎么办 辞职后提成不发怎么办 老板给客户吵架员工该怎么办 冰柜声音大怎么办嗡嗡响 交了钱电没有怎么办 小白熊电动吸奶器显示F1怎么办 花洒的水变小了怎么办 手机插卡处坏了怎么办 吉利帝豪一键启动钥匙没电怎么办 居民医保断交5年怎么办 社保和医保断了怎么办 停缴了两年社保怎么办 医保交不够20年怎么办 医保断交4个月怎么办 医保断交5个月怎么办 换城市后社保卡怎么办 苹果6s呼叫失败怎么办 苹果手机打电话显示呼叫失败怎么办 苹果手机经常呼叫失败怎么办 苹果手机呼叫号码呼叫失败怎么办 好友把我拉黑了怎么办 有人一直打骚扰电话怎么办 每天都有骚扰电话怎么办 苹果7被电话轰炸怎么办 苹果手机接听声音小怎么办 微信账号封了怎么办 在京东买的手机出现问题怎么办 销售没胆量扫楼怎么办 骨龄比实际年龄小怎么办 身体年龄比实际年龄大怎么办