zoukankan      html  css  js  c++  java
  • iOS中的分类和扩展

    一、什么是分类?

    概念:分类(Category)是OC中的特有语法,它是表示一个指向分类的结构体指针。根据下面源码组成可以看到它没有属性列表,原则上是不能添加成员变量(其实可以借助运行时功能,进行关联),只能增加方法。

    typedef struct objc_category *Category;
    struct objc_category {
    char *category_name OBJC2_UNAVAILABLE; // 分类名
    char *class_name OBJC2_UNAVAILABLE; // 分类所属的类名
    struct objc_method_list *instance_methods OBJC2_UNAVAILABLE; // 实例方法列表
    struct objc_method_list *class_methods OBJC2_UNAVAILABLE; // 类方法列表
    struct objc_protocol_list *protocols OBJC2_UNAVAILABLE; // 分类所实现的协议列表
    }

    分类的声明:

    @interface 类名(分类名)
    方法的声明;
    ...
    
    @end

    分类的实现:

    @interface 类名(分类名)
    方法的实现;
    ...
    
    @end

    作用:主要作用是为已经存在的类添加方法。在不改变原有类的前提下,动态地给这个类添加一些方法。

    注意:

    1.分类是用于给原有类添加方法的,因为分类的结构体指针中,没有属性列表,只有方法列表。

    2.分类中可以写@property,但不会生成setter/getter方法,也不会生成实现以及私有的成员变量;

    3.可以在分类中访问原有类中公开属性。

    4.如果分类中有和原有类同名的方法,会优先调用分类的方法,会忽略原有类的方法。因此在开发中尽量不要覆盖原有类的方法。

    5.如果多个分类与原有类,或者多个分类有分类间有相同的方法名,那么调用该方法的时候执行谁由编译器决定;编译器会执行最后一个参与编译的分类中的方法。

    二、什么是扩展?

    概念:Extension是Category的一个特例。类扩展与分类相比只少了分类的名称,所以称之为“匿名分类”。其实开发当中,我们几乎天天在使用。对于有些人来说像是最熟悉的陌生人。

    类扩展的格式:

    @interface XXX()
    
    私有属性;
    私有方法;(如果不实现,编译时会报警告,Method definition for 'XXX' not found)
    
    @end

    作用:为一个类添加额外的原有类没有的变量,方法和属性;一般的类扩展写到.m文件中;一般私有属性写到.m文件的类扩展中。

    注意:类扩展中添加的新方法,一定要实现。Category中没有这种限制。

    三,分类与扩展的区别

    1.类别中原则上只能增加方法(能添加属性的原因只是通过runtime解决setter/getter的问题而已);

    2.类扩展不仅可以增加方法,还可以增加实例变量(或者属性),只是改实例变量默认是@private类型的;

    3.类扩展中声明的方法没被实现,编译器会报警,但是类别中的方法没被实现的编译器不会报警的。因为类扩展是在编译阶段添加到类中,而类别是在运行时添加到类中。

    4.类扩展不能像类别那样拥有独立的实现部部分(@implement部分),类扩展所声明的方法必须依托对应类的实现部分来实现。

    5.定义在.m文件中的类扩展方法为私有的,定义在.h文件(头文件)中的文件扩展方法为公有的。

  • 相关阅读:
    javascript 字符串与正则
    微信小程序 实现三级联动-省市区
    VUE图片懒加载-vue lazyload插件的简单使用
    移动端使用mint-ui loadmore实现下拉刷新上拉显示更多
    vue-cli创建的项目中引入第三方库报错 'caller', 'calle', and 'arguments' properties .....报错问题
    js判断两个数组是否相等
    234回文链表
    剑指 Offer 22. 链表中倒数第k个节点
    返回倒数第 k 个节点
    leetcode 179.最大数
  • 原文地址:https://www.cnblogs.com/Lanht/p/10085309.html
Copyright © 2011-2022 走看看