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

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

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

    統計

    留言簿(1)

    DB

    Others

    QA

    Tech Website

    閱讀排行榜

    評論排行榜

    【轉】Avoiding Memory Leaks


    剛開始學習Anroid開發,沒有什么實際經驗,最后提出的四條建議,第二條還是不很理解,做個記號,以后解決。為了深入學習,打算閱讀《深入Java虛擬機》。
    四條優化建議:
  • Do not keep long-lived references to a context-activity (a reference to an activity should have the same life cycle as the activity itself)
  • Try using the context-application instead of a context-activity
  • Avoid non-static inner classes in an activity if you don't control their life cycle, use a static inner class and make a weak reference to the activity inside. The solution to this issue is to use a static inner class with a WeakReference to the outer class, as done in ViewRoot and its W inner class for instance
  • A garbage collector is not an insurance against memory leaks

  • ------------------

    Android applications are, at least on the T-Mobile G1, limited to 16 MB of heap. It's both a lot of memory for a phone and yet very little for what some developers want to achieve. Even if you do not plan on using all of this memory, you should use as little as possible to let other applications run without getting them killed. The more applications Android can keep in memory, the faster it will be for the user to switch between his apps. As part of my job, I ran into memory leaks issues in Android applications and they are most of the time due to the same mistake: keeping a long-lived reference to a Context.

    On Android, a Context is used for many operations but mostly to load and access resources. This is why all the widgets receive a Context parameter in their constructor. In a regular Android application, you usually have two kinds of Context, Activity and Application. It's usually the first one that the developer passes to classes and methods that need a Context:

    @Override
    protected void onCreate(Bundle state) {
    super.onCreate(state);

    TextView label = new TextView(this);
    label
    .setText("Leaks are bad");

    setContentView
    (label);
    }

    This means that views have a reference to the entire activity and therefore to anything your activity is holding onto; usually the entire View hierarchy and all its resources. Therefore, if you leak the Context ("leak" meaning you keep a reference to it thus preventing the GC from collecting it), you leak a lot of memory. Leaking an entire activity can be really easy if you're not careful.

    When the screen orientation changes the system will, by default, destroy the current activity and create a new one while preserving its state. In doing so, Android will reload the application's UI from the resources. Now imagine you wrote an application with a large bitmap that you don't want to load on every rotation. The easiest way to keep it around and not having to reload it on every rotation is to keep in a static field:

    private static Drawable sBackground;

    @Override
    protected void onCreate(Bundle state) {
    super.onCreate(state);

    TextView label = new TextView(this);
    label
    .setText("Leaks are bad");

    if (sBackground == null) {
    sBackground
    = getDrawable(R.drawable.large_bitmap);
    }
    label
    .setBackgroundDrawable(sBackground);

    setContentView
    (label);
    }

    This code is very fast and also very wrong; it leaks the first activity created upon the first screen orientation change. When a Drawable is attached to a view, the view is set as a callback on the drawable. In the code snippet above, this means the drawable has a reference to the TextView which itself has a reference to the activity (the Context) which in turns has references to pretty much anything (depending on your code.)

    This example is one of the simplest cases of leaking the Context and you can see how we worked around it in the Home screen's source code (look for the unbindDrawables() method) by setting the stored drawables' callbacks to null when the activity is destroyed. Interestingly enough, there are cases where you can create a chain of leaked contexts, and they are bad. They make you run out of memory rather quickly.

    There are two easy ways to avoid context-related memory leaks. The most obvious one is to avoid escaping the context outside of its own scope. The example above showed the case of a static reference but inner classes and their implicit reference to the outer class can be equally dangerous. The second solution is to use the Application context. This context will live as long as your application is alive and does not depend on the activities life cycle. If you plan on keeping long-lived objects that need a context, remember the application object. You can obtain it easily by calling Context.getApplicationContext() or Activity.getApplication().

    In summary, to avoid context-related memory leaks, remember the following:

    • Do not keep long-lived references to a context-activity (a reference to an activity should have the same life cycle as the activity itself)
    • Try using the context-application instead of a context-activity
    • Avoid non-static inner classes in an activity if you don't control their life cycle, use a static inner class and make a weak reference to the activity inside. The solution to this issue is to use a static inner class with a WeakReference to the outer class, as done in ViewRoot and its W inner class for instance
    • A garbage collector is not an insurance against memory leaks

    轉自:http://developers.androidcn.com/resources/articles/avoiding-memory-leaks.html

    posted on 2011-06-01 14:52 XXXXXX 閱讀(339) 評論(0)  編輯  收藏 所屬分類: Android Dev

    主站蜘蛛池模板: 国产午夜亚洲精品不卡| 亚洲Av高清一区二区三区| 特级毛片A级毛片免费播放| 午夜高清免费在线观看| 久久亚洲最大成人网4438| 18禁男女爽爽爽午夜网站免费| 亚洲AV无码码潮喷在线观看 | 亚洲欧洲日产国码www| 99久久国产免费-99久久国产免费 99久久国产免费中文无字幕 | 色婷婷亚洲一区二区三区| 日韩免费高清一级毛片在线| 亚洲精品无码专区久久| 免费国产成人午夜电影| 亚洲精品黄色视频在线观看免费资源 | AV无码免费永久在线观看| 亚洲熟妇久久精品| 免费国产高清视频| 免费无码H肉动漫在线观看麻豆| 亚洲午夜在线播放| 四虎成人精品一区二区免费网站| 久久久久久亚洲精品无码| 亚洲精品天堂成人片?V在线播放| 久久精品无码专区免费| 亚洲网址在线观看你懂的| 毛片免费观看网址| 四虎一区二区成人免费影院网址 | 亚洲成人黄色网址| 免费亚洲视频在线观看| 美女被免费网站91色| 亚洲专区中文字幕| 国产精品免费视频播放器| 中国精品一级毛片免费播放| 亚洲精品视频观看| 国产a级特黄的片子视频免费| a级成人毛片免费图片| 亚洲人配人种jizz| 亚洲综合图色40p| 一个人看www在线高清免费看| 一级特黄录像视频免费| 亚洲码在线中文在线观看| 免费a级毛片大学生免费观看|