zoukankan      html  css  js  c++  java
  • 第10条:在既有类中使用关联对象存放自定义数据

    在对象中存放相关信息的方式:

    1、从对象所属的类中继承一个子类,然后改用这个子类对象。

      然而有时类的实例可能是由某种机制所创建的,无法使用这种机制创建自己所写的子类实例。所以采用第2种方式-----“关联对象”

    2、关联对象

      可以给某对象关联多个对象,这个对象用“键”来区分,存储对象值的时,可以指明“存储策略”。存储策略由名为objc_AssociationPolicy的枚举所定义。

      对象的关联类型:

        OBJC_ASSOCIATION_ASSIGN     等价于  assign

        OBJC_ASSOCIATION_RETAIN_NONATOMIC     等价于  nonatomic, retain

        OBJC_ASSOCIATION_COPY_NONATOMIC     等价于  nonatomic, copy

        OBJC_ASSOCIATION_RETAIN     等价于  retain

        OBJC_ASSOCIATION_COPY     等价于  copy

      

      管理关联对象的方法:

        void objc_setAssociatedObject (id object, void *key, id value, objc_AssociationPolicy policy)  //以键和策略为某对象设置关联对象值

        id objc_getAssociatedObject (id object, vod *key)   //以键获取值

        void objc_removeAssociatedObject (id object)   //移除指定对象的全部关联对象。

        //为确保关联对象属于同一对象。所以键值要保持不变。通常使用静态全局变量做为键

      例: 在使用UIAlertView控件时,将view和block这两对象关联起来,这样就不用将处理放入delegate方法中了,代码放一起了。

        但实际UIAlertView使用频繁,第二种方式就不是最佳方式了,建议采用第1种方式(继承子类)。

    只有在其他做法不可行时才考虑选用关联对象,因为这种做法通常会引用难于发现的bug。

        

  • 相关阅读:
    MySQL IO线程及相关参数调优
    mysql InnoDB index 主键采用聚簇索引,二级索引不采用聚簇索引
    Mysql怎么判断繁忙 checkpoint机制 innodb的主要参数
    遇见 TiDB
    TiDB 深度实践之旅--真实“踩坑”经历
    tidb使用坑记录
    MySQL mysql server与存储引擎
    DBProxy 读写分离使用说明
    DBProxy 项目全解
    Mysql 数据库意向锁意义
  • 原文地址:https://www.cnblogs.com/Pikdays/p/4125648.html
Copyright © 2011-2022 走看看