<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 8,  comments - 6,  trackbacks - 0

    1、Context概念

    其實一直想寫一篇關(guān)于Context的文章,但是又怕技術(shù)不如而誤人子弟,于是參考了些資料,今天準(zhǔn)備整理下寫出來,如有不足,請指出,參考資料會在醒目地方標(biāo)明。

    Context,相信不管是第一天開發(fā)Android,還是開發(fā)Android的各種老鳥,對于Context的使用一定不陌生~~你在加載資源、啟動一個新的Activity、獲取系統(tǒng)服務(wù)、獲取內(nèi)部文件(夾)路徑、創(chuàng)建View操作時等都需要Context的參與,可見Context的常見性。大家可能會問到底什么是Context,Context字面意思上下文,或者叫做場景,也就是用戶與操作系統(tǒng)操作的一個過程,比如你打電話,場景包括電話程序?qū)?yīng)的界面,以及隱藏在背后的數(shù)據(jù);

    但是在程序的角度Context又是什么呢?在程序的角度,我們可以有比較權(quán)威的答案,Context是個抽象類,我們可以直接通過看其類結(jié)構(gòu)來說明答案:


    可以看到Activity、Service、Application都是Context的子類;

    也就是說,Android系統(tǒng)的角度來理解:Context是一個場景,代表與操作系統(tǒng)的交互的一種過程。從程序的角度上來理解:Context是個抽象類,而Activity、Service、Application等都是該類的一個實現(xiàn)。

    在仔細(xì)看一下上圖:Activity、Service、Application都是繼承自ContextWrapper,而ContextWrapper內(nèi)部會包含一個base context,由這個base context去實現(xiàn)了絕大多數(shù)的方法。

    先扯這么多,有能力了會從別的角度去審視Context,加油~


    2、Context與ApplicationContext

    看了標(biāo)題,千萬不要被誤解,ApplicationContext并沒有這個類,其實更應(yīng)該叫做:Activity與Application在作為Context時的區(qū)別。嗯,的確是這樣的,大家在需要Context的時候,如果是在Activity中,大多直接傳個this,當(dāng)在匿名內(nèi)部類的時候,因為this不能用,需要寫XXXActivity.this,很多哥們會偷懶,直接就來個getApplicationContext。那么大家有沒有想過,XXXActivity.this和getApplicationContext的區(qū)別呢?

    XXXActivity和getApplicationContext返回的肯定不是一個對象,一個是當(dāng)前Activity的實例,一個是項目的Application的實例。既然區(qū)別這么明顯,那么各自的使用場景肯定不同,亂使用可能會帶來一些問題。

    下面開始介紹在使用Context時,需要注意的問題。


    3、引用的保持

    大家在編寫一些類時,例如工具類,可能會編寫成單例的方式,這些工具類大多需要去訪問資源,也就說需要Context的參與。

    在這樣的情況下,就需要注意Context的引用問題。

    例如以下的寫法:

    1. package com.mooc.shader.roundimageview;  
    2.   
    3. import android.content.Context;  
    4.   
    5. public class CustomManager  
    6. {  
    7.     private static CustomManager sInstance;  
    8.     private Context mContext;  
    9.   
    10.     private CustomManager(Context context)  
    11.     {  
    12.         this.mContext = context;  
    13.     }  
    14.   
    15.     public static synchronized CustomManager getInstance(Context context)  
    16.     {  
    17.         if (sInstance == null)  
    18.         {  
    19.             sInstance = new CustomManager(context);  
    20.         }  
    21.         return sInstance;  
    22.     }  
    23.       
    24.     //some methods   
    25.     private void someOtherMethodNeedContext()  
    26.     {  
    27.           
    28.     }  
    29. }  

    對于上述的單例,大家應(yīng)該都不陌生(請別計較getInstance的效率問題),內(nèi)部保持了一個Context的引用;

    這么寫是沒有問題的,問題在于,這個Context哪來的我們不能確定,很大的可能性,你在某個Activity里面為了方便,直接傳了個this;這樣問題就來了,我們的這個類中的sInstance是一個static且強(qiáng)引用的,在其內(nèi)部引用了一個Activity作為Context,也就是說,我們的這個Activity只要我們的項目活著,就沒有辦法進(jìn)行內(nèi)存回收。而我們的Activity的生命周期肯定沒這么長,所以造成了內(nèi)存泄漏。

    那么,我們?nèi)绾尾拍鼙苊膺@樣的問題呢?

    有人會說,我們可以軟引用,嗯,軟引用,假如被回收了,你不怕NullPointException么。

    把上述代碼做下修改:

    1. public static synchronized CustomManager getInstance(Context context)  
    2.     {  
    3.         if (sInstance == null)  
    4.         {  
    5.             sInstance = new CustomManager(context.getApplicationContext());  
    6.         }  
    7.         return sInstance;  
    8.     }  

    這樣,我們就解決了內(nèi)存泄漏的問題,因為我們引用的是一個ApplicationContext,它的生命周期和我們的單例對象一致。

    這樣的話,可能有人會說,早說嘛,那我們以后都這么用不就行了,很遺憾的說,不行。上面我們已經(jīng)說過,Context和Application Context的區(qū)別是很大的,也就是說,他們的應(yīng)用場景(你也可以認(rèn)為是能力)是不同的,并非所有Activity為Context的場景,Application Context都能搞定。

    下面就開始介紹各種Context的應(yīng)用場景。


    4、Context的應(yīng)用場景



    大家注意看到有一些NO上添加了一些數(shù)字,其實這些從能力上來說是YES,但是為什么說是NO呢?下面一個一個解釋:

    數(shù)字1:啟動Activity在這些類中是可以的,但是需要創(chuàng)建一個新的task。一般情況不推薦。

    數(shù)字2:在這些類中去layout inflate是合法的,但是會使用系統(tǒng)默認(rèn)的主題樣式,如果你自定義了某些樣式可能不會被使用。

    數(shù)字3:在receiver為null時允許,在4.2或以上的版本中,用于獲取黏性廣播的當(dāng)前值。(可以無視)

    注:ContentProvider、BroadcastReceiver之所以在上述表格中,是因為在其內(nèi)部方法中都有一個context用于使用。


    好了,這里我們看下表格,重點看Activity和Application,可以看到,和UI相關(guān)的方法基本都不建議或者不可使用Application,并且,前三個操作基本不可能在Application中出現(xiàn)。實際上,只要把握住一點,凡是跟UI相關(guān)的,都應(yīng)該使用Activity做為Context來處理;其他的一些操作,Service,Activity,Application等實例都可以,當(dāng)然了,注意Context引用的持有,防止內(nèi)存泄漏。


    5、總結(jié)

    好了,到此,Context的分析基本完成了,希望大家在以后的使用過程中,能夠稍微考慮下,這里使用Activity合適嗎?會不會造成內(nèi)存泄漏?這里傳入Application work嗎?

    由于參考內(nèi)容過多,本文改為譯文咯~~

    其他精彩文章文章

    Android KSOAP2調(diào)用.net webservice

    jQuery教程(8)-DOM樹操作之使用反向插入方法

    android學(xué)習(xí)筆記(34)使用AlertDialog創(chuàng)建簡單對話框

    android學(xué)習(xí)筆記(33)畫廊視圖(Gallery)的功能和用法

    android navidgation drawer 在導(dǎo)航抽屜中如何改變List選中項的...

    更多關(guān)于android開發(fā)文章

    posted on 2015-01-05 13:40 ♂游泳的魚 閱讀(3617) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     

    <2015年1月>
    28293031123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    留言簿(1)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    主站蜘蛛池模板: 岛国岛国免费V片在线观看| 亚洲色成人网站WWW永久四虎 | 永久免费AV无码网站在线观看| 久久久婷婷五月亚洲97号色| 亚洲精品免费视频| 亚洲av无码国产精品夜色午夜| 大地影院MV在线观看视频免费| 亚洲日韩一页精品发布| 中文字幕不卡高清免费| 亚洲成在人线av| 四虎在线免费视频| 亚洲精品中文字幕无码A片老| 日本免费人成黄页在线观看视频| 国产精品亚洲综合一区在线观看| xvideos亚洲永久网址| 4hu四虎免费影院www| 久久精品国产亚洲av麻| 4444www免费看| 亚洲欧美成人av在线观看| 国产高清免费在线| 久久国产精品免费| 久久丫精品国产亚洲av| 中字幕视频在线永久在线观看免费| 亚洲欧美不卡高清在线| 亚洲国产午夜中文字幕精品黄网站| 国产一级婬片A视频免费观看| 久久精品国产亚洲av日韩| 毛片基地免费观看| www免费插插视频| 亚洲激情中文字幕| 在线观看免费毛片| 中文字幕免费在线看电影大全 | 亚洲高清无码综合性爱视频| ww在线观视频免费观看w| 亚洲男人天堂影院| 青青青国产色视频在线观看国产亚洲欧洲国产综合 | 亚洲一线产区二线产区区| 亚洲高清无码在线观看| 亚洲精品视频在线免费| 一级女性全黄久久生活片免费 | 亚洲日韩看片无码电影|