Android 内核初识(7)RefBase、LightRefBase、sp和wp

简介

  RefBase是Android中所有对象的始祖,类似MFC中的CObject及Java中的Object对象。在Android中,RefBase结合sp和wp,实现了一套通过引用计数的方法来控制对象生命周期的机制。RefBase的子类在构造一个实际对象的同时,还会悄悄地构造一个影子对象.

  sp是strong pointer,

  wp是weak pointer,

  LightRefBase是轻量级的引用计数类,只有一个引用计数,为0就删除.

RefBase,sp,wp中的引用计数

  · RefBase中有一个隐含的影子对象,该影子对象内部有强弱引用计数。
  · sp化后,强弱引用计数各增加1,sp析构后,强弱引用计数各减1。
  · wp化后,弱引用计数增加1,wp析构后,弱引用计数减1。
  · 由弱生强成功后,强弱引用计数均增加1。若一个wp弱引用计数为1,强引用计数为0,promote完成后,影子对象的强引用计数为1,弱引用计数为2。

何时删除对象

完全彻底地消灭RefBase对象,包括让实际对象和影子对象灭亡,这些都是由强弱引用计数控制的,另外还要考虑标志位mFlags的取值情况。
标志位的取值:
  · 0,
  · OBJECT_LIFETIME_WEAK= 0x0001,
  · OBJECT_LIFETIME_FOREVER = 0x0003,
当标志位为0时,可得出如下结论:
  · 强引用为0将导致实际对象被delete。
  · 弱引用为0将导致影子对象被delete。

  · flags为0,强引用计数控制实际对象的生命周期,弱引用计数控制影子对象的生命周期。强引用计数为0后,实际对象被delete。所以对于这种情况,应记住的是,使用wp时要由弱生强,以免收到segment fault信号。
  · flags为LIFETIME_WEAK,强引用计数为0,弱引用计数不为0时,实际对象不会被delete。当弱引用计数减为0时,实际对象和影子对象会同时被delete。这是功德圆满的情况。
  · flags为LIFETIME_FOREVER,对象将长生不老,彻底摆脱强弱引用计数的控制。所以你要在适当的时候杀死这些老妖精,免得她祸害“人间”。

注意

  有几个函数在release版本中是空
  addStrongRef,removeStrongRef,addWeakRef,removeWeakRef,printRefs,trackMe

posted @ 2015-09-19 15:04  f9q  阅读(467)  评论(0编辑  收藏  举报