load initialize用法_重写compareto方法

load initialize用法_重写compareto方法initialize方法与load方法比较

大家好,又见面了,我是你们的朋友全栈君。

load方法和initialize方法类似点

    1. 都只会调用一次
    2. 父类在子类之前加载
复制代码

不同点在于:

    1. 加载时间不同,load方法在main()函数前进行调用,initialize在第一次调用类的所属方法时在调用<可能永远不调用>。
    2. load方法不会被Category覆盖。
复制代码

initialize源码

//向对象发送消息时,lookUpImpOrForward函数判断对象是否初始化,没有初始化则先初始化在调用类的方法
IMP lookUpImpOrForward(Class cls, SEL sel, id inst, bool initialize, bool cache, bo ol resolver);
//第一次调用类
if (initialize && !cls->isInitialized()) {
      _class_initialize (_class_getNonMetaClass(cls, inst));
  }
  
// 第一次调用类的方法,初始化对象
void _class_initialize(Class cls) {
    Class supercls;
    bool reallyInitialize = NO;
    // 递归初始化父类
    supercls = cls->superclass;
    if (supercls && !supercls->isInitialized()) {
          _class_initialize(supercls);
    }
    {
        monitor_locker_t lock(classInitLock);
        if (!cls->isInitialized() && !cls->isInitializing()) {
              cls->setInitializing();
              reallyInitialize = YES;
        }
    }
    if (reallyInitialize) { 
        _setThisThreadIsInitializingClass(cls);
        if (MultithreadedForkChild) { performForkChildInitialize(cls, supercls);
            return;
    }
        @try {
            // 通过objc_msgSend函数调用initialize方法
                callInitialize(cls);
          }
        @catch (...) { 
            @throw;
        }
        @finally {
            // 执行initialize方法后,进行系统的initialize过程
            lockAndFinishInitializing(cls, supercls);
        }
        return;
    }
    else if (cls->isInitializing()) {
        if (_thisThreadIsInitializingClass(cls)) {
            return;
        } else if (!MultithreadedForkChild) {
            waitForInitializeToComplete(cls);
            return; 
        } else {
        _setThisThreadIsInitializingClass(cls);
        performForkChildInitialize(cls, supercls);
        }
    }
}
复制代码

转载于:https://juejin.im/post/5c74f6c2f265da2d993d9237

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106976.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • part design_PET结构

    part design_PET结构今天终于开始研究微软对于ASP.NET2.0的产品PetShop4.0了,这个产品从架构设计到编码,都有很多的想法值得去研究,而且此产品还引入了许多.net2.0的新特性。不过学习是个长期的过程,设计的思想不可能在段时间去领会,只能一个一个方面去学习和研究。今天研究了架构,遇到了不少问题,理解起来比较抽象,但还是有一点心得的。PetShop4.0采用了三层的架构,表现层、业务逻辑层和数据层。分

    2022年10月10日
    3
  • Sql server–事务

    Sql server–事务

    2021年9月8日
    60
  • CAP原理通俗理解「建议收藏」

    CAP原理通俗理解「建议收藏」在分布式系统中,有一个基本原则叫做CAP,consistence,一致性,availability,可用性,partitiontolerance分区容错性。 一致性,在这里指的是分布式系统的各个副本的值要保持同步,这里强的是空间上的一致,注意和数据库中ACID中的一致性相区分,那个一致性指的是事务执行前后的逻辑一致性,比如你转1000块给别人,不能你的账户少了1000块,对方的账户却没有多10…

    2022年5月12日
    50
  • net开源开发web框架_我的6大Web开发开源框架

    net开源开发web框架_我的6大Web开发开源框架net开源开发web框架有许多后端框架是开源的,并且易于使用,但是并非所有框架都提供了出色的功能。后端框架是网站开发的重要组成部分,因为它们就像网站的基本要素。基本上,他们处理网站幕后的一切。后端框架具有广泛的库,API,Web服务器等。他们负责数据库,确保数据库与前端进行正确的通信并生成后端功能。如所承诺的,接下来是我的前6个后端框架的摘要。1.RubyonRa…

    2022年7月15日
    35
  • C语言描述 动态规划 背包问题

    C语言描述 动态规划 背包问题动态规划作为不同于其他类型的问题,有着它自己的解题思路以及模型,以下将围绕模型以及解题思路两方面进行讲解。1.模型:有已知推到未知,是我们常用的解题思路,好比数独中如果我们有了1~8那么剩下的格子必然是9了。动态规划也是这样的思路,眼下我们有一堆货物和一个容量有限的背包,那么如何装才能利益最大化便是我们需要考虑的问题。也就是背包问题。仔细思考,不难发现,每个物品都只有0与1(0表示不装,1表示装入)两个状态,那么一串二进制数就可以表示物品的装配方案(如0101表示只带上第2、4件物品)由此必有2

    2022年7月26日
    5
  • uuid截取_jsp获取session中的值

    uuid截取_jsp获取session中的值switch_core_session_t*session=NULL;if(!(session=switch_core_session_locate(channel_uuid))){       return;}

    2022年8月10日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号