• <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
            精品熟女少妇av免费久久| 色偷偷久久一区二区三区| 国产精品女同久久久久电影院| 青青草原精品99久久精品66| 久久精品国产亚洲AV麻豆网站| 国产精品久久波多野结衣| 久久精品国产亚洲精品| 狠狠色丁香婷婷久久综合五月| 伊人久久大香线焦AV综合影院| 精品一区二区久久久久久久网站| 国产 亚洲 欧美 另类 久久| 东方aⅴ免费观看久久av| 青草影院天堂男人久久| 中文精品久久久久人妻不卡| 99久久婷婷国产一区二区| 久久综合香蕉国产蜜臀AV| 久久国产精品波多野结衣AV| 久久夜色精品国产欧美乱| 久久噜噜久久久精品66| 国产精品9999久久久久| 亚洲综合久久久| 久久伊人中文无码| 99久久精品免费看国产一区二区三区| 国产精品99久久久精品无码| 久久九九久精品国产免费直播| 精品综合久久久久久97超人| 亚洲精品综合久久| 久久se精品一区精品二区国产| 国产欧美久久久精品| 俺来也俺去啦久久综合网| 国内精品久久久久久久久电影网| 久久涩综合| 欧美日韩精品久久久久| 国产精品免费看久久久香蕉| 久久久精品人妻一区二区三区蜜桃 | 午夜福利91久久福利| 成人国内精品久久久久影院VR| 97久久综合精品久久久综合| 国产亚洲色婷婷久久99精品| 久久一日本道色综合久久| 精品午夜久久福利大片|