此文只做筆記使用实柠,不做系統(tǒng)解析LeakCanary
有關(guān)于LeakCanary的原理部分:
1.APP每次啟動(dòng)都會(huì)單獨(dú)啟動(dòng)一個(gè)進(jìn)程(屬性:process)service進(jìn)行analyze ,Android 每啟動(dòng)一個(gè)進(jìn)程都會(huì)調(diào)用Application的onCreate方法。
所以便有了:
2.使用了weakRefrenceQueue
首先:Android 有兩類引用類型:普通靠欢,refrence引用類型
refrence的子類有4種:StrongerRefrence 莱坎、softRefrence 盐肃、WeakRefrence 俯艰、 PhantomRefrence
PhantomRefrence:此類必須跟RefrenceQueue 一起使用
他們引用的對(duì)象有4種類型:
- Active:創(chuàng)建之后的對(duì)象此類型
- Pending: 等待入隊(duì)列,已經(jīng)被GC了(Refrence執(zhí)行finilize之后懂更,會(huì)被加入Pending-list)
- Enqueued:有RefrenceQueue的入隊(duì)列之后眨业,處在隊(duì)列中
- Inactive: 出隊(duì)列或者沒(méi)有Queue被GC之后的狀態(tài)急膀,一旦變?yōu)榇藸顟B(tài)此對(duì)象便不可用(拋棄)
《Java源碼分析》:ReferenceQueue、Reference及其子類
- WeakHashMap
此hashmap使用的便是WeakRefrence跟Queue龄捡,檢索沒(méi)有被引用之后回收
4.在reference類加載的時(shí)候卓嫂,java虛擬機(jī)會(huì)創(chuàng)建一個(gè)最大優(yōu)先級(jí)的后臺(tái)線程,這個(gè)線程的工作原理就是不斷檢測(cè)pending是否為null聘殖,如果不為null晨雳,就將其放入ReferenceQueue中,pending不為null的情況就是奸腺,引用所指向的對(duì)象已被GC餐禁,變?yōu)椴豢蛇_(dá)。
那么只要我們?cè)跇?gòu)造弱引用的時(shí)候指定了ReferenceQueue突照,每當(dāng)弱引用所指向的對(duì)象被內(nèi)存回收的時(shí)候帮非,我們就可以在queue中找到這個(gè)引用。如果我們期望一個(gè)對(duì)象被回收绷旗,那如果在接下來(lái)的預(yù)期時(shí)間之后喜鼓,我們發(fā)現(xiàn)它依然沒(méi)有出現(xiàn)在ReferenceQueue中副砍,那就可以判定它的內(nèi)存泄露了衔肢。LeakCanary檢測(cè)內(nèi)存泄露的核心原理就在這里。
5.關(guān)閉組件其實(shí)并不難豁翎,只要?jiǎng)?chuàng)建packageManager對(duì)象和ComponentName對(duì)象角骤,并調(diào)用packageManager對(duì)象的setComponentEnabledSetting方法。
public void setComponentEnabledSetting (ComponentName componentName, int newState, int flags)
componentName:組件名稱 newState:組件新的狀態(tài)心剥,可以設(shè)置三個(gè)值邦尊,分別是如下: 不可用狀態(tài):COMPONENT_ENABLED_STATE_DISABLED 可用狀態(tài):COMPONENT_ENABLED_STATE_ENABLED 默認(rèn)狀態(tài):COMPONENT_ENABLED_STATE_DEFAULT flags:行為標(biāo)簽,值可以是DONT_KILL_APP或者0优烧。 0說(shuō)明殺死包含該組件的app
public int getComponentEnabledSetting(ComponentName componentName)
獲取組件的狀態(tài)
- android addIdleHandler 空閑線程
loop每次從MessageQueue取出一個(gè)Message蝉揍,如果當(dāng)前隊(duì)列中沒(méi)有任何消息的時(shí),就去查找是否注冊(cè)了IdleHandler的回調(diào)畦娄,如果有的話又沾,則每個(gè)的執(zhí)行,邏輯很簡(jiǎn)單熙卡。
Looper.myQueue().addIdleHandler(new IdleHandler()
{
@Override
public boolean queueIdle()
{
// TODO Auto-generated method stub
//你想做的任何事情
return false; //為true時(shí)會(huì)一直循環(huán)調(diào)用此handler
}
});
ActivityThread 的GC便有idleHandler
這里是某些時(shí)機(jī)發(fā)送的handler
7.注冊(cè)Activity的事件: