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来实现。