weak、dealloc内部实现

weak

经过编译会调用以下两方法,
objc_initWeak
storeWeak
weak_register_no_lock
在内部先通过操作后(如判空、deallocating、isTaggedPointer),调用
weak_entry_for_referent获取 weak_entry_t (内部通过哈希查找&散列表的mask得到index,从弱引用表entiries[index]内取出地址和目标做比较,相等就直接返回,不等就index+1,继续往下偏移计算。)
类型的结构体entry,若有就把新的弱引用指针添加进入该结构体内的referrers或inline_referrers数组内;否则就新创建个
weak_entry_t 结构体类型,然后把弱引用指针加入结构体内部的可变数组内。这样也就加入到弱引用列表内了。

dealloc

_objc_rootDealloc
rootDealloc
经过一些列判断,如是否有关联对象、析构函数、非指针型isa、弱引用指针、散列表等,如无,调用c的free释放,结束。如有
调用object_dispose,内部调用objc_destructInstance将关联对象、析构函数移除掉。再调用clearDeallocating,再其内调用
weak_clear_no_lock,其内部先调用
weak_entry_for_referent获取 weak_entry_t (,内部通过哈希查找&散列表的mask得到index,从弱引用表entiries[index]内取出地址和目标做比较,相等就直接返回,不等就index+1,继续往下偏移计算。)
类型的结构体entry,根据entry计算出元素个数,拿出可变数组,遍历可变数组,判断该数组内的弱引用指针是否和当前目标对象地址一致,一致就将该遍历出来的指针置为nil

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
weak_ptr是C++11引入的一种智能指针,它可以用来解决shared_ptr的循环引用问题。weak_ptr指向一个shared_ptr管理的对象,但它不会增加该对象的引用计数,也不控制该对象的生命周期。如果shared_ptr被销毁了,那么weak_ptr就会变成空指针。 下面是一个简单的weak_ptr实现: ```c++ template<typename T> class shared_ptr; template<typename T> class weak_ptr { public: weak_ptr() : m_ptr(nullptr), m_refCount(nullptr) {} weak_ptr(const shared_ptr<T>& sp) : m_ptr(sp.m_ptr), m_refCount(sp.m_refCount) { if (m_refCount) { m_refCount->weakCount++; } } weak_ptr(const weak_ptr<T>& wp) : m_ptr(wp.m_ptr), m_refCount(wp.m_refCount) { if (m_refCount) { m_refCount->weakCount++; } } ~weak_ptr() { reset(); } weak_ptr<T>& operator=(const shared_ptr<T>& sp) { reset(); m_ptr = sp.m_ptr; m_refCount = sp.m_refCount; if (m_refCount) { m_refCount->weakCount++; } return *this; } weak_ptr<T>& operator=(const weak_ptr<T>& wp) { reset(); m_ptr = wp.m_ptr; m_refCount = wp.m_refCount; if (m_refCount) { m_refCount->weakCount++; } return *this; } void reset() { if (m_refCount) { m_refCount->weakCount--; if (m_refCount->weakCount == 0 && m_refCount->refCount == 0) { delete m_refCount; delete m_ptr; } } m_ptr = nullptr; m_refCount = nullptr; } shared_ptr<T> lock() const { if (expired()) { return shared_ptr<T>(); } else { return shared_ptr<T>(*this); } } bool expired() const { return use_count() == 0; } long use_count() const { if (m_refCount) { return m_refCount->refCount; } else { return 0; } } private: T* m_ptr; shared_ref_count* m_refCount; }; ``` 在实现中,我们需要维护一个shared_ref_count类,用来计数一个对象的引用次数和weak_ptr的数量。 ```c++ class shared_ref_count { public: shared_ref_count() : refCount(1), weakCount(0) {} long refCount; long weakCount; }; ``` 在weak_ptr的构造函数中,我们需要将weakCount增加。在析构函数中,我们需要调用reset()方法,将weakCount减少,并在refCount和weakCount都为0时释放资源。 在reset()方法中,我们首先将weakCount减少,然后判断refCount和weakCount是否都为0,如果是,则释放资源。 在lock()方法中,我们首先判断是否过期(即use_count()是否为0),如果是,则返回一个空的shared_ptr,否则返回一个新的shared_ptr。 在expired()方法中,我们判断use_count()是否为0。 在use_count()方法中,我们返回refCount的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值