framework之深入理解常见类

 RefBase、sp和wp:

         RefBase中包含一个影子对象,该对象内部有强弱引用计数

         sp化后,强弱引用计数各加1,sp析构后,强弱引用计数各减1

         wp化后,弱引用计数加1,sp析构后,弱引用计数减1

        wp的promote方法,会使强弱引用计数均增加1(由弱生强)

        extendObjectLifetime(int32_t  mode)

当mode=0;强引用计数控制实际对象的生命周期,弱引用计数控制影子对象的生命周期。强引用计数为0,实际对象delete。此时使用wp时要采用由弱生强的方式

        当mode为LIFETIME_WEAK 强引用计数为0,弱引用计数不为0时,实际对象不被delete。当弱引用计数减为0时,实际对象和影子对象同时delete

当mode为LIFETIME_FROEVER,对象长生不老,强弱引用计数无法控制。

  LightRefBase:

  只有一个引用计数支持sp的控制

  Thread类:

        theadLoop运行在一个线程中,它的返回值可以决定是否退出线程。

     Mutex(互斥类)

        用于多线程访问同一个资源的时候,保证一次只有一个线程能访问该资源。

       必须先调用lock函数,锁住该区域,如果该区域之前已被锁住,lock函数会等待,直到可以进入这块区域为止,系统保证一次只有一个线程能lock成功。

       当你使用完毕后,需unlock这块区域。

       trylock 返回值表示是否成功锁住该区域

      用AutoLock更方便

   Condition:

      Condition必须放在Mutex的lock和unlock之间的,尤其是wait函数的调用

      通知线程也需要lock,signal通知条件已经满足,但只有一个会被唤醒,broadcast(),通知所有等待者唤醒,在unlock之前。


   Looper和Handler:

    Looper类:用于封装消息循环,并且有一个消息队列。

Looper.prepare()函数设置了一个Looper的对象,这个对象保存在这个调用线程中,并且这个对象封装了一个消息队列

        Looper.loop()函数取出了Looper对象和该对象封装的消息队列(Message)

Looper.myLooper()函数返回调用线程中的Looper对象

   HandlerThread:

可以利用线程同步的方式,解决从A线程中发消息给B线程时,looper的赋值有可能为空的问题。内部采用wait、notifyAll来实现。


      

       

你可能感兴趣的:(framework之深入理解常见类)