• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預(yù)料,人們需要更細(xì)心的觀察別人,要隨時注意才能保護(hù)別人,因?yàn)樗麄兾幢刂雷约阂裁础ぁぁぁぁ?/span>
            基于Android開發(fā)應(yīng)用時,可能會挺時常出現(xiàn)Out Of Memory 異常.

              在Android中,一個Process 只能使用16M內(nèi)存,要是超過了這個限定就會跳出這個異常。這樣就要求我們要時刻想著開釋資源。Java的回收工作是交給GC的,如何讓GC能實(shí)時的回收已經(jīng)不是用的對象,這個里面有許多技巧,各人可以google一下。 

              因?yàn)榭們?nèi)存的施用超過16M而引起OOM的情況,非常簡單,我就不繼續(xù)展開說。值當(dāng)注意的是Bitmap在不用時,肯定是要recycle,不然OOM是非常容易出現(xiàn)的。 

              本文想跟各人一起討論的是另外一種情況:明明還有許多內(nèi)存,但是發(fā)生OOM了。 

              這類情況時常出現(xiàn)在生成Bitmap的時候。有興趣的可以試一下,在一個函數(shù)里生成一個13m 的int數(shù)組。

              再該函數(shù)結(jié)束后,按理說這個int數(shù)組應(yīng)該已經(jīng)被開釋了,或者說可以開釋,這個13M的空間應(yīng)該可以空出來, 

              這個時候要是你繼續(xù)生白手起家的百萬富翁成一個10M的int數(shù)組是沒有問題的,反而生成一個4M的Bitmap就會跳出OOM。這個就奇怪了,為啥子10M的int夠空間,反而4M的Bitmap不敷呢? 

              這個問題困擾好久,在網(wǎng)上,國外各大論壇搜刮了好久,一般關(guān)于OOM的解釋和解決方法都是,如何讓GC盡快回收的代碼風(fēng)格之類,并沒有現(xiàn)實(shí)的支出上面所說的情況的根源。 

              直到昨天在一個老外的blog上終于看到了這方面的解釋,我理解后歸納如下: 

              在Android中: 

              1.一個進(jìn)程的內(nèi)存可以由2個部門組成:java 施用內(nèi)存 ,C 施用內(nèi)存 ,這兩個內(nèi)存的和必需小于16M,不然就會出現(xiàn)各人熟悉的OOM,這個就是熬頭種OOM的情況。 

              2.越發(fā)奇怪的是這個:一朝內(nèi)存分配給Java后,以后這塊內(nèi)存縱然開釋后,也只能給Java的施用,這個估計(jì)跟java虛擬機(jī)里把內(nèi)存分成好幾塊進(jìn)行緩存的原因有關(guān),反正C就別想用到這塊的內(nèi)存了,所以要是Java突然占用了一個大塊內(nèi)存,縱然很快開釋了: 

              C能施用的內(nèi)存 = 16M - Java某一瞬間占在校大學(xué)生創(chuàng)業(yè)點(diǎn)子用的最大內(nèi)存。 

              而Bitmap的生成是路程經(jīng)過過程malloc進(jìn)行內(nèi)存分配的,占用的是C的內(nèi)存,這個也就說明了,上面所說的的4MBitmap無法生成的原因,因?yàn)樵?3M被Java用過后,剩下C能用的只有3M了。

            http://blog.csdn.net/ghg8699/article/details/6586853


            posted on 2011-07-03 13:30 小果子 閱讀(569) 評論(0)  編輯 收藏 引用 所屬分類: 學(xué)習(xí)筆記Android & Ios
            久久久久亚洲精品无码蜜桃| 久久国产精品国产自线拍免费| 色8激情欧美成人久久综合电| 久久精品中文字幕大胸| 国产亚洲精久久久久久无码77777| 欧洲精品久久久av无码电影| 999久久久国产精品| 久久精品无码一区二区WWW| 久久久中文字幕| 狠狠综合久久AV一区二区三区 | 亚洲精品美女久久久久99小说| 久久久精品人妻一区二区三区蜜桃| 国产精品久久久久久| 伊人久久精品影院| 99久久精品免费| 久久久精品人妻一区二区三区四| 狠狠久久综合伊人不卡| 蜜臀av性久久久久蜜臀aⅴ| 久久久久这里只有精品 | 久久亚洲精品无码AV红樱桃| 精品人妻伦九区久久AAA片69 | 久久亚洲高清综合| 久久亚洲欧美日本精品| 亚洲精品无码久久久久sm| 人人狠狠综合88综合久久| 狠狠人妻久久久久久综合蜜桃| 久久精品国产精品亚洲毛片| 一本一道久久综合狠狠老| 久久九九免费高清视频| 久久99精品免费一区二区| 91久久精品国产免费直播| 99久久精品影院老鸭窝| 久久精品人人做人人爽97| 无码人妻精品一区二区三区久久久 | 亚洲精品成人久久久| 欧美精品九九99久久在观看| 久久综合视频网站| 久久精品久久久久观看99水蜜桃| 奇米影视7777久久精品人人爽| 久久久久久免费视频| 久久无码专区国产精品发布|